:root {
  --paper: #f5ecd8;
  --paper-deep: #ead8af;
  --paper-soft: rgba(250, 244, 229, 0.84);
  --ink: #1b1510;
  --ink-soft: rgba(27, 21, 16, 0.72);
  --vermillion: #9d2f20;
  --gold: #ca9f48;
  --gold-strong: #f0d087;
  --gold-soft: rgba(202, 159, 72, 0.24);
  --shadow: 0 24px 60px rgba(53, 34, 16, 0.12);
  --shadow-strong: 0 32px 80px rgba(53, 34, 16, 0.18);
  --font-display: "STKaiti", "KaiTi", "Kaiti SC", "DFKai-SB", serif;
  --font-body: "Noto Serif SC", "Source Han Serif SC", "Songti SC", serif;
  --safe-top: env(safe-area-inset-top, 0px);
  --safe-right: env(safe-area-inset-right, 0px);
  --safe-bottom: env(safe-area-inset-bottom, 0px);
  --safe-left: env(safe-area-inset-left, 0px);
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  min-height: 100vh;
  color: var(--ink);
  font-family: var(--font-body);
  background:
    radial-gradient(circle at 18% 18%, rgba(250, 246, 236, 0.92), transparent 34%),
    radial-gradient(circle at 82% 14%, rgba(242, 226, 188, 0.56), transparent 28%),
    radial-gradient(circle at 50% 112%, rgba(198, 169, 116, 0.18), transparent 34%),
    linear-gradient(180deg, #f7f0df 0%, #efe1c0 48%, #e8d4ac 100%);
  overflow-x: hidden;
  text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
  -webkit-tap-highlight-color: transparent;
}

html,
body {
  overscroll-behavior-x: none;
}

body.is-locked { overflow: hidden; }
body.has-overlay { overflow: hidden; }

button,
input,
textarea,
select,
a {
  touch-action: manipulation;
}

main.shell > section {
  scroll-margin-top: calc(5.6rem + var(--safe-top));
}

body::before,
body::after {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: -3;
}

body::before {
  background:
    linear-gradient(90deg, transparent 0, transparent 48%, rgba(110, 88, 54, 0.04) 49%, transparent 50%, transparent 100%),
    linear-gradient(0deg, transparent 0, transparent 48%, rgba(110, 88, 54, 0.04) 49%, transparent 50%, transparent 100%);
  background-size: 168px 168px;
  mask-image: radial-gradient(circle at center, black 34%, transparent 92%);
}

body::after {
  background:
    radial-gradient(circle at 10% 22%, rgba(255, 255, 255, 0.35), transparent 18%),
    radial-gradient(circle at 76% 28%, rgba(255, 255, 255, 0.26), transparent 16%),
    radial-gradient(circle at 56% 74%, rgba(255, 255, 255, 0.18), transparent 20%);
  animation: mistDrift 22s linear infinite alternate;
  opacity: 0.8;
}

a { color: inherit; text-decoration: none; }
button, input, textarea { font: inherit; }

.screen-ritual,
.screen-result,
.screen-evolution,
.screen-castflow {
  position: fixed;
  inset: 0;
  display: grid;
  place-items: center;
  pointer-events: none;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.35s ease, visibility 0.35s ease;
  z-index: 46;
}

.screen-ritual {
  background:
    radial-gradient(circle at center, rgba(252, 246, 232, 0.86), rgba(232, 209, 160, 0.94) 52%, rgba(191, 151, 78, 0.88) 100%);
}

.screen-result {
  background:
    radial-gradient(circle at center, rgba(255, 248, 234, 0.84), rgba(238, 222, 185, 0.92) 52%, rgba(205, 167, 95, 0.82) 100%);
  z-index: 45;
}

.screen-evolution {
  background:
    radial-gradient(circle at 50% 42%, rgba(255, 246, 224, 0.2), transparent 22%),
    radial-gradient(circle at center, rgba(74, 45, 18, 0.96), rgba(37, 23, 10, 0.98) 62%, rgba(18, 11, 5, 1) 100%);
  z-index: 47;
}

.screen-castflow {
  background:
    radial-gradient(circle at 50% 32%, rgba(255, 242, 205, 0.18), transparent 18%),
    radial-gradient(circle at center, rgba(63, 39, 18, 0.96), rgba(27, 16, 8, 0.98) 60%, rgba(15, 9, 4, 1) 100%);
  z-index: 48;
}

.screen-ritual.is-active,
.screen-result.is-active,
.screen-evolution.is-active,
.screen-castflow.is-active {
  opacity: 1;
  visibility: visible;
}

.screen-result.is-active {
  pointer-events: auto;
  cursor: pointer;
}

.screen-evolution.is-active {
  pointer-events: auto;
}

.screen-castflow.is-active {
  pointer-events: auto;
}

.screen-game-ritual {
  position: fixed;
  inset: 0;
  z-index: 121;
  display: grid;
  place-items: center;
  padding: 1.2rem;
  background:
    radial-gradient(circle at center, rgba(30, 22, 16, 0.12), rgba(14, 10, 7, 0.82)),
    linear-gradient(180deg, rgba(24, 18, 12, 0.38), rgba(10, 8, 6, 0.9));
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 0.35s ease, visibility 0.35s ease;
}

.screen-game-ritual.is-active {
  opacity: 1;
  visibility: visible;
}

.screen-game-certificate {
  position: fixed;
  inset: 0;
  z-index: 122;
  display: grid;
  place-items: center;
  padding: 1rem;
  overflow: hidden;
  background:
    radial-gradient(circle at 50% 24%, rgba(255, 247, 223, 0.22), transparent 20%),
    radial-gradient(circle at 18% 16%, rgba(240, 208, 135, 0.16), transparent 22%),
    radial-gradient(circle at 82% 78%, rgba(157, 47, 32, 0.08), transparent 24%),
    linear-gradient(180deg, rgba(30, 21, 14, 0.7), rgba(10, 8, 6, 0.94));
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 0.42s ease, visibility 0.42s ease;
}

.screen-game-certificate.is-active {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

.screen-game-certificate__mist,
.screen-game-certificate__veil {
  position: absolute;
  pointer-events: none;
}

.screen-game-certificate__mist {
  width: 42rem;
  height: 42rem;
  border-radius: 50%;
  filter: blur(12px);
  opacity: 0.42;
}

.screen-game-certificate__mist--a {
  left: -10rem;
  top: -8rem;
  background: radial-gradient(circle, rgba(240, 208, 135, 0.24), transparent 70%);
  animation: certificateMistDrift 20s ease-in-out infinite;
}

.screen-game-certificate__mist--b {
  right: -12rem;
  bottom: -10rem;
  background: radial-gradient(circle, rgba(255, 248, 232, 0.18), transparent 70%);
  animation: certificateMistDrift 24s ease-in-out infinite reverse;
}

.screen-game-certificate__veil {
  border-radius: 50%;
  border: 1px solid rgba(240, 208, 135, 0.1);
  opacity: 0.45;
}

.screen-game-certificate__veil--a {
  width: 48rem;
  height: 48rem;
  left: 12%;
  top: 10%;
  animation: certificateVeilSpin 26s linear infinite;
}

.screen-game-certificate__veil--b {
  width: 34rem;
  height: 34rem;
  right: 10%;
  bottom: 6%;
  animation: certificateVeilSpin 20s linear infinite reverse;
}

.screen-game-certificate__inner {
  position: relative;
  width: min(100%, 1360px);
  height: min(100vh - 1.6rem, 930px);
  display: grid;
  place-items: center;
}

.screen-game-certificate__close {
  appearance: none;
  position: absolute;
  top: 0.4rem;
  right: 0.4rem;
  z-index: 4;
  min-width: 7.6rem;
  padding: 0.9rem 1.25rem;
  border-radius: 999px;
  border: 1px solid rgba(240, 208, 135, 0.18);
  background: rgba(255, 248, 232, 0.1);
  color: rgba(255, 245, 228, 0.96);
  letter-spacing: 0.18rem;
  font-size: 1rem;
  cursor: pointer;
  transition: transform 0.22s ease, background 0.22s ease, border-color 0.22s ease;
}

.screen-game-certificate__close:hover,
.screen-game-certificate__close:focus-visible {
  transform: translateY(-2px);
  border-color: rgba(240, 208, 135, 0.34);
  background: rgba(255, 248, 232, 0.14);
  outline: none;
}

.screen-game-certificate__frame {
  position: relative;
  width: min(100%, 1180px);
  height: min(100%, 860px);
  padding-left: 7rem;
}

.screen-game-certificate__seal {
  position: absolute;
  right: 2.4rem;
  top: 1.1rem;
  z-index: 3;
  width: 6.4rem;
  aspect-ratio: 1;
  display: grid;
  place-items: center;
  border-radius: 1.4rem;
  border: 1px solid rgba(157, 47, 32, 0.28);
  background:
    radial-gradient(circle at 34% 32%, rgba(255, 240, 220, 0.18), transparent 30%),
    linear-gradient(180deg, rgba(157, 47, 32, 0.88), rgba(122, 31, 22, 0.98));
  color: rgba(255, 244, 228, 0.96);
  font-family: var(--font-display);
  font-size: 2.35rem;
  box-shadow:
    0 1.2rem 2.4rem rgba(83, 25, 17, 0.32),
    inset 0 0 0 0.35rem rgba(255, 247, 230, 0.1);
  transform: rotate(-10deg);
  animation: certificateSealPulse 3.8s ease-in-out infinite;
}

.screen-game-certificate__rail {
  position: absolute;
  left: 0;
  top: 4.9rem;
  bottom: 4.9rem;
  width: 6rem;
  display: grid;
  gap: 1rem;
  align-content: center;
  justify-items: stretch;
  padding: 0;
  opacity: 0;
  transform: translateX(-1.1rem);
  animation: certificateRailReveal 0.82s ease forwards 0.16s;
}

.screen-game-certificate__rail::before,
.screen-game-certificate__rail::after {
  content: "";
  position: absolute;
  left: 50%;
  width: 1px;
  background: linear-gradient(180deg, transparent, rgba(240, 208, 135, 0.24), transparent);
  transform: translateX(-50%);
}

.screen-game-certificate__rail::before {
  top: -2rem;
  bottom: 52%;
}

.screen-game-certificate__rail::after {
  top: 48%;
  bottom: -2rem;
}

.screen-game-certificate__stage {
  position: relative;
  display: grid;
  justify-items: center;
  gap: 0.55rem;
  min-height: 8.6rem;
  padding: 1.1rem 0.75rem 0.9rem;
  border-radius: 1.4rem;
  border: 1px solid rgba(240, 208, 135, 0.14);
  background:
    radial-gradient(circle at 50% 12%, rgba(255, 248, 232, 0.1), transparent 28%),
    linear-gradient(180deg, rgba(34, 26, 18, 0.92), rgba(20, 15, 11, 0.98));
  color: rgba(255, 244, 226, 0.9);
  box-shadow: 0 1.2rem 2.4rem rgba(0, 0, 0, 0.2);
  opacity: 0;
  transform: translateX(-0.8rem);
  animation: certificateStageIn 0.62s ease forwards;
  animation-delay: var(--certificate-stage-delay, 0ms);
}

.screen-game-certificate__stage::before {
  content: "";
  position: absolute;
  left: 50%;
  top: -0.6rem;
  width: 0.75rem;
  height: 0.75rem;
  border-radius: 50%;
  background: linear-gradient(180deg, rgba(238, 198, 118, 0.96), rgba(154, 102, 44, 0.98));
  box-shadow: 0 0 0 3px rgba(43, 30, 20, 0.92);
  transform: translateX(-50%);
}

.screen-game-certificate__stage-chapter,
.screen-game-certificate__stage-title {
  writing-mode: vertical-rl;
  text-orientation: mixed;
}

.screen-game-certificate__stage-chapter {
  letter-spacing: 0.16rem;
  color: rgba(255, 236, 208, 0.6);
  font-size: 0.84rem;
}

.screen-game-certificate__stage-title {
  font-family: var(--font-display);
  font-size: 1.16rem;
  letter-spacing: 0.16rem;
}

.screen-game-certificate__scroll {
  position: relative;
  height: 100%;
  padding: 2.4rem 2rem 2rem;
  border-radius: 2.6rem;
  background:
    radial-gradient(circle at 50% 6%, rgba(255, 250, 238, 0.18), transparent 16%),
    linear-gradient(180deg, rgba(244, 233, 206, 0.2), rgba(223, 197, 143, 0.08));
  box-shadow:
    0 2.6rem 4.8rem rgba(0, 0, 0, 0.28),
    inset 0 0 0 1px rgba(240, 208, 135, 0.1);
  opacity: 0;
  transform-origin: 50% 0%;
  transform: translateY(1.6rem) scaleY(0.88);
  animation: certificateScrollUnfurl 0.9s cubic-bezier(0.2, 0.84, 0.22, 1) forwards;
}

.screen-game-certificate__scroll-edge {
  position: absolute;
  left: 2.2rem;
  right: 2.2rem;
  height: 1.25rem;
  border-radius: 999px;
  background:
    linear-gradient(90deg, rgba(142, 87, 41, 0.96), rgba(215, 171, 97, 0.94), rgba(117, 69, 30, 0.96));
  box-shadow:
    0 0.55rem 1.2rem rgba(63, 39, 18, 0.22),
    inset 0 0 0 1px rgba(255, 244, 220, 0.18);
}

.screen-game-certificate__scroll-edge--top { top: 0.9rem; }
.screen-game-certificate__scroll-edge--bottom { bottom: 0.9rem; }

.screen-game-certificate__paper {
  position: relative;
  height: 100%;
  padding: 2.2rem 1.8rem 2.3rem;
  border-radius: 2rem;
  border: 1px solid rgba(171, 120, 47, 0.14);
  background:
    radial-gradient(circle at 84% 14%, rgba(240, 208, 135, 0.2), transparent 16%),
    radial-gradient(circle at 20% 14%, rgba(255, 255, 255, 0.48), transparent 16%),
    linear-gradient(180deg, rgba(255, 253, 248, 0.99), rgba(248, 238, 215, 0.98));
  overflow: hidden;
}

.screen-game-certificate__paper::before,
.screen-game-certificate__paper::after {
  content: "";
  position: absolute;
  pointer-events: none;
}

.screen-game-certificate__paper::before {
  inset: 1.1rem;
  border: 1px solid rgba(171, 120, 47, 0.12);
  border-radius: 1.45rem;
}

.screen-game-certificate__paper::after {
  inset: 0;
  background:
    radial-gradient(circle at 12% 18%, rgba(157, 47, 32, 0.04), transparent 16%),
    radial-gradient(circle at 84% 82%, rgba(157, 47, 32, 0.05), transparent 20%);
}

.screen-game-certificate__columns {
  position: relative;
  z-index: 1;
  height: 100%;
  display: grid;
  grid-template-columns: 1.2fr 1fr 1.08fr 1.42fr 0.92fr;
  gap: 1.3rem;
  align-items: stretch;
}

.screen-game-certificate__column {
  min-height: 100%;
  display: grid;
  justify-items: center;
  align-content: start;
  gap: 1rem;
  padding: 1.2rem 0.65rem;
  border-left: none;
  border-right: 1px solid rgba(171, 120, 47, 0.12);
  opacity: 0;
  transform: translateY(1rem);
  animation: certificateColumnReveal 0.72s ease forwards;
  animation-delay: calc(180ms + var(--certificate-column-index, 0) * 110ms);
  position: relative;
}

.screen-game-certificate__column:first-child {
  padding-left: 1rem;
}

.screen-game-certificate__column:last-child {
  border-right: none;
  padding-right: 0.95rem;
}

.screen-game-certificate__column-label,
.screen-game-certificate__column-text {
  margin: 0;
}

.screen-game-certificate__column-label {
  writing-mode: horizontal-tb;
  text-orientation: mixed;
  padding: 0.22rem 0.6rem;
  border-radius: 999px;
  border: 1px solid rgba(171, 120, 47, 0.14);
  background: rgba(255, 249, 236, 0.92);
  letter-spacing: 0.18rem;
  color: rgba(98, 68, 33, 0.72);
  font-size: 0.86rem;
}

.screen-game-certificate__column-text {
  writing-mode: vertical-rl;
  text-orientation: mixed;
  white-space: pre-wrap;
  line-height: 2.12;
  color: rgba(27, 21, 16, 0.92);
  text-shadow: 0 1px 0 rgba(255, 255, 255, 0.2);
  font-size: 1.12rem;
}

.screen-game-certificate__column--title .screen-game-certificate__column-text,
.screen-game-certificate__column--heading .screen-game-certificate__column-text {
  font-family: var(--font-display);
}

.screen-game-certificate__column--title .screen-game-certificate__column-text {
  font-size: clamp(2.65rem, 3.4vw, 3.85rem);
  letter-spacing: 0.24rem;
  color: rgba(22, 16, 11, 0.96);
}

.screen-game-certificate__column--heading .screen-game-certificate__column-text {
  font-size: clamp(1.8rem, 2.2vw, 2.45rem);
  color: rgba(118, 28, 22, 0.96);
}

.screen-game-certificate__column--outline .screen-game-certificate__column-text {
  font-size: 1.08rem;
  color: rgba(121, 84, 37, 0.9);
}

.screen-game-certificate__column--subtitle .screen-game-certificate__column-text {
  font-size: 1.18rem;
  color: rgba(57, 40, 23, 0.8);
}

.screen-game-certificate__column--body .screen-game-certificate__column-text {
  font-size: 1.22rem;
}

.screen-game-certificate__column--grant .screen-game-certificate__column-text,
.screen-game-certificate__column--date .screen-game-certificate__column-text {
  color: rgba(57, 40, 23, 0.78);
}

.screen-game-ritual__mist {
  position: absolute;
  width: 46rem;
  height: 46rem;
  border-radius: 50%;
  filter: blur(2px);
  opacity: 0.45;
  pointer-events: none;
}

.screen-game-ritual__mist--a {
  left: -8rem;
  top: -10rem;
  background: radial-gradient(circle, rgba(240, 208, 135, 0.26), transparent 72%);
  animation: mistFloat 18s ease-in-out infinite;
}

.screen-game-ritual__mist--b {
  right: -10rem;
  bottom: -12rem;
  background: radial-gradient(circle, rgba(255, 245, 224, 0.2), transparent 72%);
  animation: mistFloat 20s ease-in-out infinite reverse;
}

.screen-game-ritual__inner {
  position: relative;
  width: min(100%, 1180px);
  border-radius: 2rem;
  padding: 2rem 2rem 2.2rem;
  border: 1px solid rgba(240, 208, 135, 0.16);
  background:
    radial-gradient(circle at 50% 24%, rgba(255, 250, 236, 0.08), transparent 32%),
    linear-gradient(180deg, rgba(24, 18, 12, 0.92), rgba(16, 12, 9, 0.96));
  box-shadow: 0 2.2rem 4rem rgba(0, 0, 0, 0.28);
}

.screen-game-ritual__header {
  display: grid;
  gap: 0.25rem;
  justify-items: center;
  text-align: center;
}

.screen-game-ritual__narrative {
  display: grid;
  gap: 0.55rem;
  justify-items: center;
  margin-top: 1rem;
  min-height: 6.8rem;
}

.screen-game-ritual__script-line {
  margin: 0;
  max-width: min(88%, 62rem);
  text-align: center;
  line-height: 1.95;
  color: rgba(255, 240, 216, 0.76);
  opacity: 0;
  transform: translateY(0.9rem);
  animation: revealUp 0.72s ease forwards;
  animation-delay: var(--script-delay, 0ms);
}

.screen-game-ritual__label,
.screen-game-ritual__note,
.screen-game-ritual__panel-note {
  margin: 0;
  letter-spacing: 0.18rem;
  color: rgba(255, 241, 216, 0.68);
}

.screen-game-ritual__title,
.screen-game-ritual__result,
.screen-game-ritual__panel-title {
  margin: 0;
  font-family: var(--font-display);
  color: rgba(255, 245, 230, 0.98);
}

.screen-game-ritual__title {
  font-size: clamp(2.5rem, 4vw, 4rem);
}

.screen-game-ritual__stage {
  position: relative;
  overflow: hidden;
  margin-top: 1.4rem;
  min-height: 28rem;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(240px, 320px) minmax(0, 1fr);
  gap: 1.2rem;
  align-items: center;
}

.screen-game-ritual__scene {
  position: absolute;
  inset: 0;
  border-radius: 1.6rem;
  overflow: hidden;
  opacity: 0;
  transition: opacity 0.3s ease;
  pointer-events: none;
}

.screen-game-ritual__wing,
.screen-game-ritual__core {
  position: relative;
  z-index: 1;
  border-radius: 1.5rem;
  border: 1px solid rgba(240, 208, 135, 0.12);
  background:
    radial-gradient(circle at 50% 18%, rgba(255, 246, 226, 0.14), transparent 20%),
    linear-gradient(180deg, rgba(255, 250, 242, 0.14), rgba(255, 250, 242, 0.04));
  backdrop-filter: blur(5px);
  min-height: 20rem;
  padding: 1rem;
}

.screen-game-ritual__wing {
  display: grid;
  place-items: center;
  overflow: hidden;
}

.screen-game-ritual__wing::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 50% 16%, rgba(255, 248, 228, 0.1), transparent 18%),
    linear-gradient(135deg, rgba(240, 208, 135, 0.08), transparent 34%);
  pointer-events: none;
}

.screen-game-ritual__panel {
  display: grid;
  gap: 0.6rem;
  justify-items: center;
  text-align: center;
}

.screen-game-ritual__panel-figure .figure,
.screen-game-ritual__figure .figure {
  min-width: 10rem;
}

.screen-game-ritual__panel-title {
  font-size: 1.6rem;
}

.screen-game-ritual__panel-note {
  line-height: 1.8;
}

.screen-game-ritual__figure .figure__line {
  min-height: 0.88rem;
}

.screen-game-ritual__core {
  display: grid;
  align-content: center;
  justify-items: center;
  gap: 0.9rem;
}

.screen-game-ritual__seal {
  width: 5.2rem;
  aspect-ratio: 1;
  display: grid;
  place-items: center;
  border-radius: 50%;
  border: 1px solid rgba(240, 208, 135, 0.22);
  background: radial-gradient(circle, rgba(164, 52, 32, 0.22), rgba(164, 52, 32, 0.08));
  color: rgba(255, 240, 216, 0.92);
  font-family: var(--font-display);
  font-size: 2rem;
}

.screen-game-ritual__result {
  font-size: clamp(1.8rem, 3vw, 2.8rem);
}

.screen-game-ritual[data-mode="realm"] .screen-game-ritual__scene {
  opacity: 1;
}

.screen-game-ritual__scene-glow,
.screen-game-ritual__scene-moon,
.screen-game-ritual__scene-mist,
.screen-game-ritual__scene-hill,
.screen-game-ritual__scene-temple,
.screen-game-ritual__scene-lantern,
.screen-game-ritual__scene-elder,
.screen-game-ritual__scene-mirror,
.screen-game-ritual__scene-orbit,
.screen-game-ritual__scene-tower,
.screen-game-ritual__scene-plaque,
.screen-game-ritual__scene-card,
.screen-game-ritual__scene-lines {
  position: absolute;
  opacity: 0;
}

.screen-game-ritual__scene-glow {
  border-radius: 50%;
  filter: blur(22px);
}

.screen-game-ritual__scene-glow--a {
  width: 22rem;
  height: 22rem;
  left: 6%;
  top: -8%;
}

.screen-game-ritual__scene-glow--b {
  width: 28rem;
  height: 20rem;
  right: 4%;
  bottom: -10%;
}

.screen-game-ritual__scene-moon {
  left: 10%;
  top: 12%;
  width: 6.4rem;
  height: 6.4rem;
  border-radius: 50%;
  background: radial-gradient(circle at 35% 35%, rgba(255, 252, 238, 0.95), rgba(240, 208, 135, 0.8) 58%, rgba(240, 208, 135, 0.18) 78%, transparent 82%);
  box-shadow: 0 0 2rem rgba(240, 208, 135, 0.26);
}

.screen-game-ritual__scene-mist {
  width: 34rem;
  height: 12rem;
  border-radius: 50%;
  filter: blur(24px);
}

.screen-game-ritual__scene-mist--a {
  left: -2rem;
  bottom: 3.6rem;
}

.screen-game-ritual__scene-mist--b {
  right: -4rem;
  bottom: 1.4rem;
}

.screen-game-ritual__scene-hill {
  bottom: 0;
  clip-path: polygon(0 100%, 24% 54%, 44% 76%, 62% 40%, 100% 100%);
}

.screen-game-ritual__scene-hill--a {
  left: -3%;
  width: 36%;
  height: 46%;
}

.screen-game-ritual__scene-hill--b {
  left: 22%;
  width: 34%;
  height: 54%;
}

.screen-game-ritual__scene-hill--c {
  right: -2%;
  width: 40%;
  height: 48%;
}

.screen-game-ritual__scene-temple,
.screen-game-ritual__scene-tower {
  border-radius: 0.6rem;
}

.screen-game-ritual__scene-temple {
  right: 16%;
  bottom: 4.8rem;
  width: 9.8rem;
  height: 6.4rem;
  background:
    linear-gradient(180deg, rgba(96, 73, 48, 0.88), rgba(67, 49, 31, 0.96));
  box-shadow: 0 1rem 1.6rem rgba(0, 0, 0, 0.22);
}

.screen-game-ritual__scene-temple::before,
.screen-game-ritual__scene-temple::after,
.screen-game-ritual__scene-tower::before,
.screen-game-ritual__scene-tower::after {
  content: "";
  position: absolute;
}

.screen-game-ritual__scene-temple::before {
  left: -0.6rem;
  right: -0.6rem;
  top: -1rem;
  height: 1.3rem;
  border-radius: 0.8rem 0.8rem 0 0;
  background: linear-gradient(180deg, rgba(120, 88, 56, 0.94), rgba(68, 48, 30, 0.98));
  clip-path: polygon(0 100%, 12% 24%, 50% 0, 88% 24%, 100% 100%);
}

.screen-game-ritual__scene-temple::after {
  inset: 1rem 1.3rem 0.9rem;
  background:
    linear-gradient(90deg, transparent 0, transparent 24%, rgba(248, 233, 196, 0.82) 24%, rgba(248, 233, 196, 0.82) 29%, transparent 29%, transparent 47%, rgba(248, 233, 196, 0.82) 47%, rgba(248, 233, 196, 0.82) 52%, transparent 52%, transparent 70%, rgba(248, 233, 196, 0.82) 70%, rgba(248, 233, 196, 0.82) 75%, transparent 75%);
}

.screen-game-ritual__scene-lantern {
  right: 28%;
  top: 20%;
  width: 1rem;
  height: 4.6rem;
  background: linear-gradient(180deg, rgba(98, 78, 54, 0.3), rgba(98, 78, 54, 0.9) 28%, transparent 28%);
}

.screen-game-ritual__scene-lantern::before,
.screen-game-ritual__scene-lantern::after {
  content: "";
  position: absolute;
  left: 50%;
  translate: -50% 0;
}

.screen-game-ritual__scene-lantern::before {
  top: 1rem;
  width: 2rem;
  height: 2.7rem;
  border-radius: 1rem;
  background: radial-gradient(circle at 50% 35%, rgba(255, 245, 214, 0.94), rgba(240, 208, 135, 0.94) 52%, rgba(157, 47, 32, 0.96) 100%);
  box-shadow: 0 0 1.8rem rgba(240, 208, 135, 0.34);
}

.screen-game-ritual__scene-lantern::after {
  top: 3.6rem;
  width: 0.14rem;
  height: 1rem;
  background: rgba(240, 208, 135, 0.9);
}

.screen-game-ritual__scene-elder {
  left: 18%;
  bottom: 5rem;
  width: 4.4rem;
  height: 9.6rem;
}

.screen-game-ritual__scene-elder::before,
.screen-game-ritual__scene-elder::after {
  content: "";
  position: absolute;
  left: 50%;
  translate: -50% 0;
}

.screen-game-ritual__scene-elder::before {
  top: 0;
  width: 1.6rem;
  height: 1.6rem;
  border-radius: 50%;
  background: rgba(238, 223, 186, 0.9);
  box-shadow: 0 0 1rem rgba(255, 245, 214, 0.2);
}

.screen-game-ritual__scene-elder::after {
  top: 1.3rem;
  width: 4rem;
  height: 8rem;
  border-radius: 2rem 2rem 0.9rem 0.9rem;
  background: linear-gradient(180deg, rgba(72, 59, 46, 0.94), rgba(36, 29, 23, 0.98));
  clip-path: polygon(34% 0, 66% 0, 82% 30%, 100% 100%, 0 100%, 18% 30%);
}

.screen-game-ritual__scene-mirror {
  left: 44%;
  bottom: 4.2rem;
  width: 7rem;
  height: 7rem;
  border-radius: 50%;
  border: 1px solid rgba(240, 208, 135, 0.36);
  background:
    radial-gradient(circle at 50% 50%, rgba(255, 248, 231, 0.16), rgba(54, 67, 82, 0.12) 46%, rgba(14, 20, 28, 0.56) 82%);
  box-shadow: 0 0 2rem rgba(240, 208, 135, 0.18);
}

.screen-game-ritual__scene-orbit {
  left: 39%;
  bottom: 1.2rem;
  width: 17rem;
  height: 17rem;
  border-radius: 50%;
  border: 1px solid rgba(240, 208, 135, 0.18);
}

.screen-game-ritual__scene-symbols {
  position: absolute;
  left: calc(39% + 8.5rem);
  bottom: calc(1.2rem + 8.5rem);
  width: 0;
  height: 0;
}

.screen-game-ritual__scene-symbols span {
  position: absolute;
  width: 2.2rem;
  height: 2.2rem;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: rgba(255, 250, 242, 0.92);
  color: rgba(42, 32, 22, 0.88);
  font-family: var(--font-display);
  box-shadow: 0 0.6rem 1rem rgba(0, 0, 0, 0.16);
  opacity: 0;
}

.screen-game-ritual__scene-symbols span:nth-child(1) { transform: rotate(0deg) translateY(-8rem) rotate(0deg); }
.screen-game-ritual__scene-symbols span:nth-child(2) { transform: rotate(45deg) translateY(-8rem) rotate(-45deg); }
.screen-game-ritual__scene-symbols span:nth-child(3) { transform: rotate(90deg) translateY(-8rem) rotate(-90deg); }
.screen-game-ritual__scene-symbols span:nth-child(4) { transform: rotate(135deg) translateY(-8rem) rotate(-135deg); }
.screen-game-ritual__scene-symbols span:nth-child(5) { transform: rotate(180deg) translateY(-8rem) rotate(-180deg); }
.screen-game-ritual__scene-symbols span:nth-child(6) { transform: rotate(225deg) translateY(-8rem) rotate(-225deg); }
.screen-game-ritual__scene-symbols span:nth-child(7) { transform: rotate(270deg) translateY(-8rem) rotate(-270deg); }
.screen-game-ritual__scene-symbols span:nth-child(8) { transform: rotate(315deg) translateY(-8rem) rotate(-315deg); }

.screen-game-ritual__scene-tower {
  left: 50%;
  bottom: 3.6rem;
  width: 12rem;
  height: 12.6rem;
  translate: -50% 0;
  background:
    linear-gradient(180deg, rgba(86, 66, 44, 0.9), rgba(46, 34, 22, 0.98));
  clip-path: polygon(18% 100%, 18% 28%, 28% 28%, 28% 0, 72% 0, 72% 28%, 82% 28%, 82% 100%);
  box-shadow: 0 1rem 2rem rgba(0, 0, 0, 0.2);
}

.screen-game-ritual__scene-tower::before {
  left: -1rem;
  right: -1rem;
  top: 1.8rem;
  height: 1rem;
  background: linear-gradient(180deg, rgba(118, 86, 56, 0.96), rgba(64, 43, 27, 0.98));
  clip-path: polygon(0 100%, 10% 0, 90% 0, 100% 100%);
}

.screen-game-ritual__scene-tower::after {
  left: 2rem;
  right: 2rem;
  top: 5rem;
  height: 4.8rem;
  background:
    linear-gradient(90deg, transparent 0, transparent 28%, rgba(248, 233, 196, 0.82) 28%, rgba(248, 233, 196, 0.82) 32%, transparent 32%, transparent 49%, rgba(248, 233, 196, 0.82) 49%, rgba(248, 233, 196, 0.82) 53%, transparent 53%, transparent 70%, rgba(248, 233, 196, 0.82) 70%, rgba(248, 233, 196, 0.82) 74%, transparent 74%);
}

.screen-game-ritual__scene-plaque {
  left: 50%;
  top: 16%;
  width: 9rem;
  height: 2.8rem;
  translate: -50% 0;
  border-radius: 999px;
  background: linear-gradient(180deg, rgba(111, 33, 21, 0.98), rgba(83, 18, 12, 0.98));
  box-shadow: 0 0.8rem 1.4rem rgba(0, 0, 0, 0.18);
}

.screen-game-ritual__scene-card {
  top: 18%;
  width: 6.2rem;
  height: 9rem;
  border-radius: 1rem;
  background:
    linear-gradient(180deg, rgba(255, 252, 246, 0.98), rgba(247, 236, 208, 0.96));
  border: 1px solid rgba(214, 183, 121, 0.72);
  box-shadow: 0 1rem 1.8rem rgba(0, 0, 0, 0.2);
}

.screen-game-ritual__scene-card::before,
.screen-game-ritual__scene-card::after {
  content: "";
  position: absolute;
  left: 50%;
  translate: -50% 0;
}

.screen-game-ritual__scene-card::before {
  top: 1.4rem;
  width: 2.6rem;
  height: 0.46rem;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(202, 159, 72, 0.98), rgba(240, 208, 135, 0.98));
  box-shadow: 0 1.3rem 0 rgba(202, 159, 72, 0.94), 0 2.6rem 0 rgba(202, 159, 72, 0.9);
}

.screen-game-ritual__scene-card::after {
  top: 5.4rem;
  width: 1.8rem;
  height: 1.8rem;
  border-radius: 50%;
  border: 1px solid rgba(157, 47, 32, 0.42);
}

.screen-game-ritual__scene-card--upper {
  left: 18%;
}

.screen-game-ritual__scene-card--lower {
  right: 18%;
}

.screen-game-ritual__scene-lines {
  left: 50%;
  bottom: 5rem;
  width: 10rem;
  height: 12rem;
  translate: -50% 0;
}

.screen-game-ritual__scene-lines::before,
.screen-game-ritual__scene-lines::after {
  content: "";
  position: absolute;
  left: 50%;
  translate: -50% 0;
  width: 7rem;
  height: 0.52rem;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(202, 159, 72, 0.96), rgba(240, 208, 135, 0.96));
  box-shadow:
    0 1.7rem 0 rgba(202, 159, 72, 0.94),
    0 3.4rem 0 rgba(202, 159, 72, 0.9),
    0 5.1rem 0 rgba(202, 159, 72, 0.88),
    0 6.8rem 0 rgba(202, 159, 72, 0.84),
    0 8.5rem 0 rgba(202, 159, 72, 0.8);
}

.screen-game-ritual__scene-lines::after {
  width: 0.18rem;
  height: 9rem;
  background: rgba(255, 245, 220, 0.12);
  box-shadow: none;
}

.screen-game-ritual[data-realm="taichu"] .screen-game-ritual__inner {
  background:
    radial-gradient(circle at 50% 18%, rgba(255, 248, 226, 0.12), transparent 28%),
    linear-gradient(180deg, rgba(34, 26, 18, 0.94), rgba(18, 14, 10, 0.98));
}

.screen-game-ritual[data-realm="taichu"] .screen-game-ritual__core::before,
.screen-game-ritual[data-realm="liangyi"] .screen-game-ritual__core::before {
  content: "";
  position: absolute;
  inset: 16%;
  border-radius: 50%;
  border: 1px solid rgba(240, 208, 135, 0.18);
  pointer-events: none;
}

.screen-game-ritual[data-realm="taichu"] .screen-game-ritual__core::before {
  animation: spinSlow 11s linear infinite;
}

.screen-game-ritual[data-realm="liangyi"] .screen-game-ritual__inner {
  background:
    radial-gradient(circle at 50% 22%, rgba(240, 208, 135, 0.08), transparent 26%),
    linear-gradient(180deg, rgba(20, 15, 11, 0.94), rgba(10, 8, 6, 0.98));
}

.screen-game-ritual[data-realm="liangyi"] .screen-game-ritual__core::before {
  inset: 18% 22%;
  border-radius: 1.2rem;
  animation: pulseRing 3.8s ease-in-out infinite;
}

.screen-game-ritual[data-realm="taichu"] .screen-game-ritual__scene {
  background:
    radial-gradient(circle at 18% 18%, rgba(255, 246, 224, 0.08), transparent 22%),
    linear-gradient(180deg, rgba(19, 25, 40, 0.94), rgba(10, 13, 24, 0.98) 54%, rgba(17, 13, 10, 0.96) 100%);
}

.screen-game-ritual[data-realm="taichu"] .screen-game-ritual__scene-glow--a {
  background: radial-gradient(circle, rgba(92, 111, 168, 0.34), transparent 72%);
}

.screen-game-ritual[data-realm="taichu"] .screen-game-ritual__scene-glow--b {
  background: radial-gradient(circle, rgba(240, 208, 135, 0.18), transparent 72%);
}

.screen-game-ritual[data-realm="taichu"] .screen-game-ritual__scene-mist {
  background: radial-gradient(circle, rgba(170, 191, 220, 0.16), transparent 72%);
}

.screen-game-ritual[data-realm="taichu"] .screen-game-ritual__scene-hill {
  background: linear-gradient(180deg, rgba(44, 56, 74, 0.98), rgba(24, 30, 42, 0.98));
}

.screen-game-ritual[data-realm="taichu"] .screen-game-ritual__scene-tower,
.screen-game-ritual[data-realm="taichu"] .screen-game-ritual__scene-plaque,
.screen-game-ritual[data-realm="taichu"] .screen-game-ritual__scene-card,
.screen-game-ritual[data-realm="taichu"] .screen-game-ritual__scene-lines {
  display: none;
}

.screen-game-ritual[data-realm="liangyi"] .screen-game-ritual__scene {
  background:
    radial-gradient(circle at 50% 12%, rgba(255, 246, 224, 0.08), transparent 20%),
    linear-gradient(180deg, rgba(22, 16, 11, 0.96), rgba(10, 8, 6, 0.98));
}

.screen-game-ritual[data-realm="liangyi"] .screen-game-ritual__scene-glow--a {
  background: radial-gradient(circle, rgba(240, 208, 135, 0.18), transparent 72%);
}

.screen-game-ritual[data-realm="liangyi"] .screen-game-ritual__scene-glow--b {
  background: radial-gradient(circle, rgba(157, 47, 32, 0.16), transparent 72%);
}

.screen-game-ritual[data-realm="liangyi"] .screen-game-ritual__scene-moon,
.screen-game-ritual[data-realm="liangyi"] .screen-game-ritual__scene-temple,
.screen-game-ritual[data-realm="liangyi"] .screen-game-ritual__scene-lantern,
.screen-game-ritual[data-realm="liangyi"] .screen-game-ritual__scene-elder,
.screen-game-ritual[data-realm="liangyi"] .screen-game-ritual__scene-mirror,
.screen-game-ritual[data-realm="liangyi"] .screen-game-ritual__scene-orbit,
.screen-game-ritual[data-realm="liangyi"] .screen-game-ritual__scene-symbols,
.screen-game-ritual[data-realm="liangyi"] .screen-game-ritual__scene-hill {
  display: none;
}

.screen-game-ritual.is-active[data-realm="taichu"] .screen-game-ritual__scene-glow--a,
.screen-game-ritual.is-active[data-realm="taichu"] .screen-game-ritual__scene-glow--b {
  animation: realmGlow 2.6s ease-in-out both;
}

.screen-game-ritual.is-active[data-realm="taichu"] .screen-game-ritual__scene-moon {
  animation: realmMoonRise 1.2s 0.18s ease-out both;
}

.screen-game-ritual.is-active[data-realm="taichu"] .screen-game-ritual__scene-hill {
  animation: realmLandReveal 1.15s ease both;
}

.screen-game-ritual.is-active[data-realm="taichu"] .screen-game-ritual__scene-temple {
  animation: realmFadeIn 0.9s 0.55s ease both;
}

.screen-game-ritual.is-active[data-realm="taichu"] .screen-game-ritual__scene-lantern {
  animation: realmLanternGlow 1.2s 0.92s ease both;
}

.screen-game-ritual.is-active[data-realm="taichu"] .screen-game-ritual__scene-elder {
  animation: realmElderAppear 1s 1.05s ease both;
}

.screen-game-ritual.is-active[data-realm="taichu"] .screen-game-ritual__scene-mirror {
  animation: realmMirrorAwaken 1.1s 1.4s ease both;
}

.screen-game-ritual.is-active[data-realm="taichu"] .screen-game-ritual__scene-orbit {
  animation: realmOrbitGlow 1.1s 1.7s ease both;
}

.screen-game-ritual.is-active[data-realm="taichu"] .screen-game-ritual__scene-symbols {
  animation: spinSlow 14s linear infinite;
}

.screen-game-ritual.is-active[data-realm="taichu"] .screen-game-ritual__scene-symbols span {
  animation: realmSymbolFloat 0.8s ease both;
}

.screen-game-ritual.is-active[data-realm="taichu"] .screen-game-ritual__scene-symbols span:nth-child(1) { animation-delay: 1.82s; }
.screen-game-ritual.is-active[data-realm="taichu"] .screen-game-ritual__scene-symbols span:nth-child(2) { animation-delay: 1.92s; }
.screen-game-ritual.is-active[data-realm="taichu"] .screen-game-ritual__scene-symbols span:nth-child(3) { animation-delay: 2.02s; }
.screen-game-ritual.is-active[data-realm="taichu"] .screen-game-ritual__scene-symbols span:nth-child(4) { animation-delay: 2.12s; }
.screen-game-ritual.is-active[data-realm="taichu"] .screen-game-ritual__scene-symbols span:nth-child(5) { animation-delay: 2.22s; }
.screen-game-ritual.is-active[data-realm="taichu"] .screen-game-ritual__scene-symbols span:nth-child(6) { animation-delay: 2.32s; }
.screen-game-ritual.is-active[data-realm="taichu"] .screen-game-ritual__scene-symbols span:nth-child(7) { animation-delay: 2.42s; }
.screen-game-ritual.is-active[data-realm="taichu"] .screen-game-ritual__scene-symbols span:nth-child(8) { animation-delay: 2.52s; }

.screen-game-ritual.is-active[data-realm="liangyi"] .screen-game-ritual__scene-glow--a,
.screen-game-ritual.is-active[data-realm="liangyi"] .screen-game-ritual__scene-glow--b {
  animation: realmGlow 2.4s ease-in-out both;
}

.screen-game-ritual.is-active[data-realm="liangyi"] .screen-game-ritual__scene-tower {
  animation: realmFadeIn 1s 0.42s ease both;
}

.screen-game-ritual.is-active[data-realm="liangyi"] .screen-game-ritual__scene-plaque {
  animation: realmPlaqueReveal 0.9s 0.78s ease both;
}

.screen-game-ritual.is-active[data-realm="liangyi"] .screen-game-ritual__scene-card--upper {
  animation: realmCardUpperIn 1.05s 1.05s cubic-bezier(0.2, 0.92, 0.28, 1) both;
}

.screen-game-ritual.is-active[data-realm="liangyi"] .screen-game-ritual__scene-card--lower {
  animation: realmCardLowerIn 1.05s 1.15s cubic-bezier(0.2, 0.92, 0.28, 1) both;
}

.screen-game-ritual.is-active[data-realm="liangyi"] .screen-game-ritual__scene-lines {
  animation: realmLinesAssemble 1s 1.58s ease both;
}

@keyframes realmGlow {
  0% { opacity: 0; transform: scale(0.84); }
  100% { opacity: 1; transform: scale(1); }
}

@keyframes realmMoonRise {
  0% { opacity: 0; transform: translateY(1.4rem) scale(0.76); }
  100% { opacity: 1; transform: translateY(0) scale(1); }
}

@keyframes realmLandReveal {
  0% { opacity: 0; transform: translateY(1.4rem) scaleY(0.88); }
  100% { opacity: 1; transform: translateY(0) scaleY(1); }
}

@keyframes realmFadeIn {
  0% { opacity: 0; transform: translateY(1rem); }
  100% { opacity: 1; transform: translateY(0); }
}

@keyframes realmLanternGlow {
  0% { opacity: 0; transform: translateY(-0.8rem); }
  100% { opacity: 1; transform: translateY(0); }
}

@keyframes realmElderAppear {
  0% { opacity: 0; transform: translateY(1.2rem) scale(0.88); }
  100% { opacity: 1; transform: translateY(0) scale(1); }
}

@keyframes realmMirrorAwaken {
  0% { opacity: 0; transform: scale(0.64); box-shadow: 0 0 0 rgba(240, 208, 135, 0); }
  60% { opacity: 1; transform: scale(1.08); box-shadow: 0 0 2.8rem rgba(240, 208, 135, 0.22); }
  100% { opacity: 1; transform: scale(1); box-shadow: 0 0 2rem rgba(240, 208, 135, 0.18); }
}

@keyframes realmOrbitGlow {
  0% { opacity: 0; transform: scale(0.82); }
  100% { opacity: 1; transform: scale(1); }
}

@keyframes realmSymbolFloat {
  0% { opacity: 0; transform: scale(0.72); filter: blur(4px); }
  100% { opacity: 1; transform: scale(1); filter: blur(0); }
}

@keyframes realmPlaqueReveal {
  0% { opacity: 0; transform: translate(-50%, -0.9rem); }
  100% { opacity: 1; transform: translate(-50%, 0); }
}

@keyframes realmCardUpperIn {
  0% { opacity: 0; transform: translate3d(-20vw, -4rem, 0) rotate(-16deg); }
  100% { opacity: 1; transform: translate3d(0, 0, 0) rotate(-4deg); }
}

@keyframes realmCardLowerIn {
  0% { opacity: 0; transform: translate3d(20vw, 4rem, 0) rotate(16deg); }
  100% { opacity: 1; transform: translate3d(0, 0, 0) rotate(4deg); }
}

@keyframes realmLinesAssemble {
  0% { opacity: 0; transform: translate(-50%, 1.4rem) scale(0.82); }
  100% { opacity: 1; transform: translate(-50%, 0) scale(1); }
}

.screen-game-ritual.is-active .screen-game-ritual__wing--upper {
  animation: gameRitualUpperIn 1.05s cubic-bezier(0.2, 0.92, 0.28, 1) both;
}

.screen-game-ritual.is-active .screen-game-ritual__wing--lower {
  animation: gameRitualLowerIn 1.05s cubic-bezier(0.2, 0.92, 0.28, 1) both;
}

.screen-game-ritual.is-active .screen-game-ritual__core {
  animation: evolutionFusionIn 0.92s 0.24s cubic-bezier(0.2, 0.92, 0.28, 1) both;
}

.screen-game-ritual[data-mode="reflect"].is-active .screen-game-ritual__wing--upper {
  animation: evolutionWingLeft 1s cubic-bezier(0.2, 0.92, 0.28, 1) both;
}

.screen-game-ritual[data-mode="reflect"].is-active .screen-game-ritual__wing--lower {
  animation: evolutionWingRight 1s cubic-bezier(0.2, 0.92, 0.28, 1) both;
}

.screen-game-ritual[data-mode="rise"].is-active .screen-game-ritual__core {
  animation-duration: 1.05s;
}

.screen-ritual__mist,
.screen-result__halo {
  position: absolute;
  width: 28rem;
  height: 28rem;
  border-radius: 50%;
  filter: blur(24px);
}

.screen-ritual__mist--a,
.screen-result__halo--a {
  left: 8%;
  top: 12%;
  background: radial-gradient(circle, rgba(255, 255, 255, 0.4), transparent 70%);
  animation: washFloat 13s ease-in-out infinite;
}

.screen-ritual__mist--b,
.screen-result__halo--b {
  right: 8%;
  bottom: 10%;
  background: radial-gradient(circle, rgba(240, 208, 135, 0.32), transparent 72%);
  animation: washFloat 15s ease-in-out infinite reverse;
}

.screen-ritual__core,
.screen-result__inner {
  position: relative;
  display: grid;
  justify-items: center;
  gap: 1rem;
}

.screen-ritual__core {
  width: min(74vw, 36rem);
  aspect-ratio: 1;
}

.screen-ritual__ring,
.screen-ritual__seal {
  position: absolute;
  inset: 50%;
  translate: -50% -50%;
}

.screen-ritual__ring {
  border-radius: 50%;
  border: 1px solid rgba(255, 239, 200, 0.72);
  box-shadow: 0 0 1.5rem rgba(240, 208, 135, 0.2);
}

.screen-ritual__ring--a {
  width: 11rem;
  height: 11rem;
  animation: spinSlow 3.8s linear infinite;
}

.screen-ritual__ring--b {
  width: 17rem;
  height: 17rem;
  border-style: dashed;
  animation: spinSlow 7s linear infinite reverse;
}

.screen-ritual__ring--c {
  width: 25rem;
  height: 25rem;
  opacity: 0.48;
  animation: resultPulse 1.3s ease-in-out infinite;
}

.screen-ritual__seal {
  width: 6rem;
  height: 6rem;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background:
    radial-gradient(circle at 30% 20%, rgba(255, 255, 255, 0.22), transparent 28%),
    linear-gradient(135deg, rgba(157, 47, 32, 0.98), rgba(121, 26, 19, 0.96));
  color: #fbf2df;
  font-family: var(--font-display);
  font-size: 2.1rem;
  box-shadow: 0 1.2rem 2.8rem rgba(125, 31, 23, 0.26);
  animation: sealBeat 1.25s ease-in-out infinite;
}

.screen-ritual__text {
  position: absolute;
  left: 50%;
  bottom: 2.8rem;
  translate: -50% 0;
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(1.3rem, 2.6vw, 2rem);
  letter-spacing: 0.3rem;
  color: rgba(48, 30, 18, 0.92);
}

.screen-ritual__dust {
  position: absolute;
  inset: 0;
}

.screen-ritual__spark {
  background: radial-gradient(circle, rgba(255, 243, 214, 0.98), rgba(240, 208, 135, 0.22) 62%, transparent 78%);
  box-shadow: 0 0 1rem rgba(240, 208, 135, 0.42);
  animation-name: dustSpiral;
  animation-iteration-count: infinite;
}

.screen-result__inner {
  width: min(90vw, 60rem);
  padding: 2rem 2rem 2.4rem;
  border-radius: 2rem;
  background: linear-gradient(180deg, rgba(255, 250, 241, 0.64), rgba(248, 236, 206, 0.42));
  border: 1px solid rgba(233, 204, 136, 0.35);
  box-shadow: 0 2rem 4rem rgba(111, 74, 24, 0.14);
}

.screen-result__seal {
  width: 5rem;
  height: 5rem;
  display: grid;
  place-items: center;
  border: 1px solid rgba(157, 47, 32, 0.54);
  color: var(--vermillion);
  font-family: var(--font-display);
  font-size: 1.8rem;
  transform: rotate(-7deg);
  box-shadow: inset 0 0 0 0.3rem rgba(157, 47, 32, 0.06);
}

.screen-result__main {
  display: grid;
  justify-items: center;
  gap: 0.55rem;
}

.screen-result__label {
  margin: 0;
  color: var(--ink-soft);
  letter-spacing: 0.24rem;
}

.screen-result__title {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(2rem, 4vw, 3.4rem);
  letter-spacing: 0.18rem;
  color: rgba(28, 18, 10, 0.94);
  animation: fadeSlide 0.6s ease both;
}

.screen-result__list {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.9rem;
  width: 100%;
  margin-top: 0.8rem;
}

.screen-result__item {
  display: grid;
  gap: 0.3rem;
  padding: 0.9rem 1rem;
  border-radius: 1rem;
  background: rgba(255, 249, 237, 0.72);
  border: 1px solid rgba(202, 159, 72, 0.2);
  opacity: 0;
  transform: translateY(10px) scale(0.98);
  animation: revealCard 0.55s ease forwards;
  animation-delay: var(--reveal-delay, 0ms);
}

.screen-result__item-label {
  color: var(--ink-soft);
  font-size: 0.82rem;
  letter-spacing: 0.18rem;
}

.screen-result__item-value {
  font-family: var(--font-display);
  font-size: 1.16rem;
  color: rgba(39, 25, 15, 0.92);
}

.sky-effects {
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: -2;
  overflow: hidden;
}

.sky-effects__wash {
  position: absolute;
  width: 42rem;
  height: 42rem;
  border-radius: 50%;
  filter: blur(18px);
  opacity: 0.46;
}

.sky-effects__wash--a {
  left: -8rem;
  top: -16rem;
  background: radial-gradient(circle, rgba(255, 255, 255, 0.48), transparent 68%);
  animation: washFloat 15s ease-in-out infinite;
}

.sky-effects__wash--b {
  right: -10rem;
  top: -12rem;
  background: radial-gradient(circle, rgba(240, 208, 135, 0.28), transparent 72%);
  animation: washFloat 18s ease-in-out infinite reverse;
}

.sky-effects__stars {
  position: absolute;
  inset: 0 0 auto;
  height: 46vh;
}

.sky-effects__star,
.hero__spark,
.casting__spark,
.sky-effects__petal {
  position: absolute;
  left: var(--x);
  top: var(--y);
  width: var(--size);
  height: var(--size);
  border-radius: 50%;
  animation-delay: var(--delay);
  animation-duration: var(--duration);
}

.sky-effects__star {
  background: radial-gradient(circle, rgba(255, 255, 255, 0.86), rgba(240, 208, 135, 0.35) 55%, transparent 72%);
  box-shadow: 0 0 0.9rem rgba(255, 247, 224, 0.55);
  animation-name: starBlink;
  animation-iteration-count: infinite;
}

.sky-effects__edge {
  position: absolute;
  top: 0;
  bottom: 0;
  width: clamp(5.6rem, 9vw, 9rem);
  overflow: hidden;
}

.sky-effects__edge--left {
  left: 0;
}

.sky-effects__edge--right {
  right: 0;
}

.sky-effects__edge::before,
.sky-effects__edge::after {
  content: "";
  position: absolute;
  pointer-events: none;
}

.sky-effects__edge::before {
  top: -6%;
  bottom: -6%;
  width: 1px;
  background: linear-gradient(180deg, transparent, rgba(202, 159, 72, 0.18) 14%, rgba(202, 159, 72, 0.06) 52%, rgba(202, 159, 72, 0.14) 86%, transparent);
  filter: blur(0.4px);
}

.sky-effects__edge--left::before {
  right: 1.1rem;
}

.sky-effects__edge--right::before {
  left: 1.1rem;
}

.sky-effects__edge::after {
  top: 0;
  bottom: 0;
  width: 100%;
  background:
    linear-gradient(90deg, rgba(255, 250, 240, 0.18), transparent 38%, transparent 100%);
  opacity: 0.48;
}

.sky-effects__edge--right::after {
  background: linear-gradient(270deg, rgba(255, 250, 240, 0.18), transparent 38%, transparent 100%);
}

.sky-effects__edge-mist {
  position: absolute;
  width: 10rem;
  height: 18rem;
  border-radius: 50%;
  filter: blur(24px);
  opacity: 0.42;
  background: radial-gradient(circle, rgba(255, 255, 255, 0.54), rgba(240, 208, 135, 0.18) 48%, transparent 72%);
  animation: sideMistFloat 16s ease-in-out infinite;
}

.sky-effects__edge--left .sky-effects__edge-mist--a {
  left: -4rem;
  top: 4%;
}

.sky-effects__edge--left .sky-effects__edge-mist--b {
  left: -3rem;
  bottom: 10%;
  animation-duration: 19s;
  animation-direction: reverse;
}

.sky-effects__edge--right .sky-effects__edge-mist--a {
  right: -4rem;
  top: 12%;
}

.sky-effects__edge--right .sky-effects__edge-mist--b {
  right: -3rem;
  bottom: 4%;
  animation-duration: 18s;
  animation-direction: reverse;
}

.sky-effects__petals {
  position: absolute;
  inset: 0;
}

.sky-effects__petal {
  width: calc(var(--size) * 1.65);
  height: calc(var(--size) * 1.1);
  border-radius: 62% 38% 58% 42%;
  background:
    radial-gradient(circle at 32% 28%, rgba(255, 255, 255, 0.92), transparent 28%),
    linear-gradient(135deg, rgba(251, 239, 244, 0.96), rgba(221, 176, 192, 0.92));
  box-shadow: 0 0.45rem 0.9rem rgba(173, 103, 120, 0.12);
  opacity: 0.74;
  animation-name: sidePetalFall;
  animation-iteration-count: infinite;
}

.sky-effects__edge--right .sky-effects__petal {
  animation-name: sidePetalFallRight;
}

.sky-effects__sigil {
  position: absolute;
  display: grid;
  place-items: center;
  width: 3.1rem;
  height: 3.1rem;
  border-radius: 1rem;
  border: 1px solid rgba(157, 47, 32, 0.18);
  background:
    radial-gradient(circle at 28% 22%, rgba(255, 255, 255, 0.3), transparent 28%),
    rgba(249, 241, 226, 0.44);
  color: rgba(157, 47, 32, 0.42);
  font-family: var(--font-display);
  font-size: 1.28rem;
  box-shadow: inset 0 0 0 0.24rem rgba(157, 47, 32, 0.03);
  animation: sideSigilFloat 14s ease-in-out infinite;
}

.sky-effects__edge--left .sky-effects__sigil--upper {
  top: 18%;
  left: 1rem;
  transform: rotate(-10deg);
}

.sky-effects__edge--left .sky-effects__sigil--lower {
  top: 64%;
  left: 1.55rem;
  transform: rotate(7deg);
  animation-duration: 16s;
}

.sky-effects__edge--right .sky-effects__sigil--upper {
  top: 24%;
  right: 1rem;
  transform: rotate(9deg);
}

.sky-effects__edge--right .sky-effects__sigil--lower {
  top: 70%;
  right: 1.55rem;
  transform: rotate(-8deg);
  animation-duration: 15s;
}

@media (max-width: 1160px) {
  .sky-effects__edge {
    display: none;
  }
}

.intro {
  position: fixed;
  inset: 0;
  display: grid;
  place-items: center;
  background: radial-gradient(circle at center, rgba(248, 242, 226, 0.74) 0%, rgba(235, 219, 184, 0.92) 48%, rgba(220, 194, 140, 0.98) 100%);
  z-index: 50;
  overflow: hidden;
  transition: opacity 0.55s ease, visibility 0.55s ease;
}

.intro.is-leaving {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

.intro__mist {
  position: absolute;
  width: min(42vw, 520px);
  height: min(42vw, 520px);
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255, 255, 255, 0.34) 0%, rgba(255, 255, 255, 0.08) 48%, transparent 72%);
  filter: blur(18px);
}

.intro__mist--a { top: 8%; left: 10%; animation: mistFloat 18s ease-in-out infinite; }
.intro__mist--b { right: 8%; top: 16%; animation: mistFloat 15s ease-in-out infinite reverse; }
.intro__mist--c { bottom: 6%; left: 30%; animation: mistFloat 20s ease-in-out infinite; }

.intro__core {
  position: relative;
  display: grid;
  justify-items: center;
  gap: 1rem;
  padding: 3rem 2rem;
}

.intro__core::before,
.intro__core::after {
  content: "";
  position: absolute;
  inset: 50%;
  translate: -50% -50%;
  border-radius: 50%;
  pointer-events: none;
}

.intro__core::before {
  width: min(74vw, 620px);
  height: min(74vw, 620px);
  border: 1px solid rgba(141, 98, 47, 0.24);
  animation: spinSlow 18s linear infinite;
}

.intro__core::after {
  width: min(58vw, 430px);
  height: min(58vw, 430px);
  border: 2px solid rgba(157, 47, 32, 0.18);
  animation: pulseRing 4.6s ease-in-out infinite;
}

.intro__seal {
  position: relative;
  width: 5.5rem;
  height: 5.5rem;
  display: grid;
  place-items: center;
  border: 2px solid rgba(157, 47, 32, 0.72);
  color: var(--vermillion);
  font-family: var(--font-display);
  font-size: 2.35rem;
  letter-spacing: 0.18rem;
  transform: rotate(-8deg);
  box-shadow: inset 0 0 0 0.4rem rgba(157, 47, 32, 0.08);
  animation: sealBeat 3.8s ease-in-out infinite;
}

.intro__title {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(3rem, 7vw, 5.6rem);
  font-weight: 600;
  letter-spacing: 0.25rem;
  color: rgba(38, 28, 20, 0.92);
  text-shadow: 0 0.2rem 1.4rem rgba(255, 255, 255, 0.44);
}

.intro__enter {
  appearance: none;
  border: 1px solid rgba(157, 47, 32, 0.48);
  background: linear-gradient(135deg, rgba(157, 47, 32, 0.94), rgba(128, 31, 21, 0.94));
  color: #f9f2e4;
  padding: 0.9rem 2.3rem;
  border-radius: 999px;
  letter-spacing: 0.3rem;
  cursor: pointer;
  box-shadow: 0 1.2rem 2.4rem rgba(128, 31, 21, 0.18);
  transform: translateY(1.2rem);
  opacity: 0;
  transition: transform 0.5s ease, opacity 0.5s ease, box-shadow 0.4s ease;
}

.intro.is-ready .intro__enter { transform: translateY(0); opacity: 1; }

.app-topbar,
.app-tabbar {
  display: none;
}

.site-icp {
  width: min(1200px, calc(100% - 2.6rem));
  margin: 1.8rem auto 2.4rem;
  padding: 0.95rem 1rem;
  text-align: center;
  color: rgba(98, 71, 44, 0.72);
  font-size: 0.82rem;
  letter-spacing: 0.08em;
}

.site-icp__link {
  color: inherit;
  text-decoration: none;
  border-bottom: 1px solid rgba(157, 107, 62, 0.28);
  transition: color 0.25s ease, border-color 0.25s ease;
}

.site-icp__link:hover,
.site-icp__link:focus-visible {
  color: rgba(143, 74, 44, 0.92);
  border-color: rgba(143, 74, 44, 0.52);
}

.topbar {
  position: sticky;
  top: 0;
  z-index: 20;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1rem clamp(1.2rem, 3vw, 2.2rem);
  background: linear-gradient(180deg, rgba(250, 244, 229, 0.94), rgba(250, 244, 229, 0.68));
  backdrop-filter: blur(12px);
  border-bottom: 1px solid rgba(117, 84, 48, 0.12);
}

.topbar::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -1px;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(240, 208, 135, 0.8), transparent);
}

.topbar__brand { font-family: var(--font-display); font-size: 1.4rem; letter-spacing: 0.16rem; }

.topbar__nav { display: flex; gap: 0.75rem; flex-wrap: wrap; }

.topbar__actions {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.layout-switch {
  display: inline-flex;
  align-items: center;
  padding: 0.22rem;
  border-radius: 999px;
  background: rgba(255, 250, 240, 0.88);
  border: 1px solid rgba(126, 90, 55, 0.14);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.28);
}

.layout-switch__button {
  appearance: none;
  min-width: 4.1rem;
  padding: 0.46rem 0.9rem;
  border: 0;
  border-radius: 999px;
  background: transparent;
  color: var(--ink-soft);
  transition: background 0.3s ease, color 0.3s ease, transform 0.3s ease;
}

.layout-switch__button.is-active {
  background: rgba(157, 47, 32, 0.1);
  color: var(--vermillion);
  transform: translateY(-1px);
}

.topbar__link {
  padding: 0.45rem 0.9rem;
  border-radius: 999px;
  font-size: 0.96rem;
  color: var(--ink-soft);
  transition: background 0.3s ease, color 0.3s ease, transform 0.3s ease;
}

.topbar__link:hover {
  background: rgba(157, 47, 32, 0.08);
  color: var(--vermillion);
  transform: translateY(-1px);
}

.topbar__link.is-active {
  background: rgba(157, 47, 32, 0.11);
  color: var(--vermillion);
  box-shadow: inset 0 0 0 1px rgba(157, 47, 32, 0.08);
}

.desktop-dock {
  position: sticky;
  top: 5.25rem;
  z-index: 18;
  padding: 0.8rem 0 0;
}

.desktop-dock__inner {
  width: min(1320px, calc(100% - 2rem));
  margin: 0 auto;
  padding: 0.78rem 0.9rem;
  border-radius: 1.35rem;
  border: 1px solid rgba(117, 84, 48, 0.12);
  background: linear-gradient(180deg, rgba(250, 244, 229, 0.94), rgba(248, 240, 222, 0.82));
  box-shadow: 0 1rem 2rem rgba(109, 78, 40, 0.08);
  backdrop-filter: blur(12px);
}

.desktop-dock__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 0.55rem;
}

.desktop-dock__label {
  margin: 0;
  color: var(--ink-soft);
  font-size: 0.82rem;
  letter-spacing: 0.16rem;
}

.desktop-dock__rail {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(8.2rem, 1fr));
  gap: 0.7rem;
}

.desktop-dock__button {
  appearance: none;
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  gap: 0.7rem;
  padding: 0.74rem 0.82rem;
  border-radius: 1rem;
  border: 1px solid rgba(157, 47, 32, 0.08);
  background: rgba(255, 252, 246, 0.82);
  color: var(--ink-strong);
  text-align: left;
  transition: transform 0.3s ease, border-color 0.3s ease, background 0.3s ease, box-shadow 0.3s ease;
}

.desktop-dock__button:hover {
  transform: translateY(-1px);
  border-color: rgba(157, 47, 32, 0.2);
  background: rgba(255, 249, 240, 0.96);
}

.desktop-dock__button.is-active {
  border-color: rgba(157, 47, 32, 0.28);
  background:
    radial-gradient(circle at 18% 24%, rgba(255, 255, 255, 0.18), transparent 28%),
    linear-gradient(135deg, rgba(157, 47, 32, 0.96), rgba(126, 31, 21, 0.94));
  color: #fff6e8;
  box-shadow: 0 1rem 2rem rgba(128, 31, 21, 0.16);
}

.desktop-dock__seal {
  width: 2.3rem;
  height: 2.3rem;
  display: grid;
  place-items: center;
  border-radius: 999px;
  background: rgba(204, 167, 76, 0.12);
  font-family: var(--font-display);
  font-size: 1rem;
}

.desktop-dock__button.is-active .desktop-dock__seal {
  background: rgba(255, 247, 229, 0.16);
}

.desktop-dock__copy {
  min-width: 0;
  display: grid;
  gap: 0.08rem;
}

.desktop-dock__title {
  font-size: 0.98rem;
  font-weight: 600;
  letter-spacing: 0.05rem;
}

.desktop-dock__note {
  font-size: 0.78rem;
  color: var(--ink-soft);
}

.desktop-dock__button.is-active .desktop-dock__note {
  color: rgba(255, 246, 232, 0.76);
}

body.is-android-app .topbar {
  display: none;
}

body.is-android-app .topbar__actions,
body.is-android-app .desktop-dock {
  display: none;
}

body.is-android-app .app-topbar {
  position: sticky;
  top: 0;
  z-index: 24;
  display: flex;
  align-items: center;
  gap: 0.85rem;
  padding:
    calc(0.7rem + var(--safe-top))
    calc(0.9rem + var(--safe-right))
    0.72rem
    calc(0.9rem + var(--safe-left));
  background: rgba(248, 239, 220, 0.98);
  border-bottom: 1px solid rgba(117, 84, 48, 0.1);
}

body.is-android-app .app-topbar__back {
  appearance: none;
  min-width: 3.5rem;
  padding: 0.48rem 0.78rem;
  border-radius: 999px;
  border: 1px solid rgba(126, 90, 55, 0.14);
  background: rgba(255, 251, 243, 0.88);
  color: var(--ink-strong);
}

body.is-android-app .app-topbar__titles {
  min-width: 0;
  display: grid;
  gap: 0.08rem;
}

body.is-android-app .app-topbar__eyebrow {
  margin: 0;
  color: var(--ink-soft);
  letter-spacing: 0.14rem;
  font-size: 0.74rem;
}

body.is-android-app .app-topbar__title {
  margin: 0;
  font-family: var(--font-display);
  font-size: 1.55rem;
  color: var(--ink-strong);
}

body.is-android-app .app-tabbar {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 26;
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 0.3rem;
  padding:
    0.48rem
    calc(0.55rem + var(--safe-right))
    calc(0.48rem + var(--safe-bottom))
    calc(0.55rem + var(--safe-left));
  background: rgba(248, 239, 220, 0.98);
  border-top: 1px solid rgba(117, 84, 48, 0.1);
}

body.is-android-app .app-tabbar__button {
  appearance: none;
  display: grid;
  justify-items: center;
  gap: 0.18rem;
  padding: 0.42rem 0.1rem;
  border: 0;
  border-radius: 1rem;
  background: transparent;
  color: var(--ink-soft);
}

body.is-android-app .app-tabbar__button.is-active {
  background: rgba(157, 47, 32, 0.08);
  color: var(--vermillion);
}

body.is-android-app .app-tabbar__seal {
  width: 1.9rem;
  height: 1.9rem;
  display: grid;
  place-items: center;
  border-radius: 999px;
  background: rgba(204, 167, 76, 0.14);
  font-family: var(--font-display);
  font-size: 0.92rem;
}

body.is-android-app .app-tabbar__label {
  font-size: 0.66rem;
  letter-spacing: 0.02rem;
  line-height: 1.1;
  text-align: center;
}

.shell {
  width: min(1320px, calc(100% - 2rem));
  margin: 0 auto;
  padding: 1.2rem 0 4rem;
}

body.is-mobile-ui .topbar {
  align-items: flex-start;
  flex-direction: column;
  gap: 0.7rem;
  padding:
    calc(0.82rem + var(--safe-top))
    calc(0.9rem + var(--safe-right))
    0.82rem
    calc(0.9rem + var(--safe-left));
  backdrop-filter: none;
}

body.is-mobile-ui .topbar__nav {
  width: 100%;
  flex-wrap: nowrap;
  overflow-x: auto;
  padding-bottom: 0.15rem;
  scrollbar-width: none;
}

body.is-mobile-ui .topbar__nav::-webkit-scrollbar {
  display: none;
}

body.is-mobile-ui .topbar__link {
  flex: 0 0 auto;
  white-space: nowrap;
}

body.is-mobile-ui .topbar__actions,
body.is-mobile-ui .desktop-dock {
  display: none;
}

body.is-mobile-ui .shell {
  width: min(100% - 0.7rem, 1320px);
  padding:
    0.85rem
    calc(var(--safe-right) + 0rem)
    calc(2rem + var(--safe-bottom))
    calc(var(--safe-left) + 0rem);
}

body.is-mobile-ui input,
body.is-mobile-ui textarea,
body.is-mobile-ui select,
body.is-mobile-ui button {
  font-size: 16px;
}

body.is-android-app .shell {
  width: min(100% - 0.7rem, 1320px);
  padding:
    0.6rem
    calc(var(--safe-right) + 0rem)
    calc(6rem + var(--safe-bottom))
    calc(var(--safe-left) + 0rem);
}

body.is-android-app [data-app-screen] {
  display: none;
  min-height: calc(100dvh - 9.8rem - var(--safe-top) - var(--safe-bottom));
}

body.is-android-app [data-app-screen].is-app-active {
  display: block;
}

body.is-desktop-focus .shell {
  padding-top: calc(7.2rem + var(--safe-top));
}

body.is-desktop-focus [data-app-screen] {
  min-height: calc(100dvh - 10.8rem);
}

body.is-desktop-focus .topbar {
  display: none;
}

body.is-desktop-focus .desktop-dock {
  top: 0;
  padding-top: 0;
  z-index: 22;
}

body.is-desktop-focus .desktop-dock__inner {
  width: 100%;
  border-radius: 0;
  border-left: 0;
  border-right: 0;
  border-top: 0;
  padding:
    0.82rem
    clamp(1.2rem, 3vw, 2.2rem)
    0.9rem;
  box-shadow: 0 0.8rem 1.8rem rgba(109, 78, 40, 0.08);
}

body.is-desktop-focus .desktop-dock__rail {
  grid-template-columns: repeat(auto-fit, minmax(8.6rem, 1fr));
}

body.is-desktop-focus .layout-switch--dock {
  flex: 0 0 auto;
}

body.is-desktop-focus .layout-switch:not(.layout-switch--dock) {
  display: none;
}

.hero,
.panel,
.trigram-showcase,
.season-compass,
.qi-scroll,
.heluo-atlas,
.daoyi-hall,
.mingli-hall,
.culture-hall,
.xiang-hall,
.hexagram-flow,
.game-lab,
.academy,
.hall {
  position: relative;
  border: 1px solid rgba(109, 78, 40, 0.12);
  background: linear-gradient(180deg, rgba(251, 246, 235, 0.86), rgba(244, 235, 214, 0.78));
  box-shadow: var(--shadow);
  overflow: hidden;
}

.trigram-showcase,
.season-compass,
.qi-scroll,
.heluo-atlas,
.daoyi-hall,
.mingli-hall,
.culture-hall,
.xiang-hall,
.hexagram-flow,
.panel,
.oracle,
.game-lab,
.academy,
.hall {
  content-visibility: auto;
  contain-intrinsic-size: 960px;
}

.oracle-catalog,
.academy__body,
.game-lab__body,
.gua-grid,
.screen-evolution__matrix,
.hexagram-flow__preview {
  content-visibility: auto;
  contain-intrinsic-size: 720px;
}

.hero::before,
.panel::before,
.trigram-showcase::before,
.season-compass::before,
.qi-scroll::before,
.heluo-atlas::before,
.daoyi-hall::before,
.mingli-hall::before,
.culture-hall::before,
.xiang-hall::before,
.hexagram-flow::before,
.game-lab::before,
.academy::before,
.hall::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 12% 14%, rgba(255, 255, 255, 0.26), transparent 16%),
    radial-gradient(circle at 88% 14%, rgba(185, 145, 74, 0.12), transparent 14%),
    linear-gradient(135deg, transparent 0 24%, rgba(157, 47, 32, 0.03) 42%, transparent 66%);
  pointer-events: none;
}

.hero {
  margin-top: 1rem;
  border-radius: 2rem;
  min-height: 42rem;
  --season-accent: #a95a4f;
  --season-accent-strong: #cb7568;
  --season-soft: rgba(208, 170, 160, 0.22);
  --season-sky-top: rgba(252, 245, 234, 0.98);
  --season-sky-bottom: rgba(242, 228, 202, 0.92);
  --season-mist: rgba(255, 255, 255, 0.7);
  --season-sun: rgba(250, 210, 158, 0.82);
  --season-mount-back: #d6c7b0;
  --season-mount-mid: #a2937a;
  --season-mount-front: #68543f;
  --season-water-top: rgba(141, 167, 161, 0.54);
  --season-water-bottom: rgba(96, 122, 116, 0.84);
  --season-branch: #62412f;
  --season-branch-highlight: #816046;
  --season-bloom: linear-gradient(135deg, rgba(253, 240, 244, 0.98), rgba(221, 174, 189, 0.92));
  --season-drift: linear-gradient(135deg, rgba(252, 239, 243, 0.98), rgba(230, 183, 198, 0.92));
}

.hero::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background:
    linear-gradient(90deg, rgba(114, 82, 45, 0.08), transparent 8%, transparent 92%, rgba(114, 82, 45, 0.08)),
    linear-gradient(180deg, rgba(255, 255, 255, 0.2), transparent 18%, transparent 82%, rgba(202, 159, 72, 0.08));
  pointer-events: none;
}

.hero[data-season="summer"] {
  --season-accent: #7f6a2d;
  --season-accent-strong: #9d8740;
  --season-soft: rgba(157, 135, 64, 0.22);
  --season-sky-top: rgba(246, 239, 221, 0.98);
  --season-sky-bottom: rgba(232, 222, 186, 0.92);
  --season-mist: rgba(255, 247, 230, 0.68);
  --season-sun: rgba(249, 213, 137, 0.82);
  --season-mount-back: #cdbd92;
  --season-mount-mid: #7f7c57;
  --season-mount-front: #4f603e;
  --season-water-top: rgba(96, 143, 121, 0.56);
  --season-water-bottom: rgba(66, 102, 82, 0.86);
  --season-branch: #4c4128;
  --season-branch-highlight: #716039;
  --season-bloom: linear-gradient(135deg, rgba(177, 209, 126, 0.95), rgba(109, 149, 82, 0.92));
  --season-drift: linear-gradient(135deg, rgba(177, 209, 126, 0.9), rgba(109, 149, 82, 0.84));
}

.hero[data-season="autumn"] {
  --season-accent: #b06a34;
  --season-accent-strong: #cf8f57;
  --season-soft: rgba(198, 145, 92, 0.22);
  --season-sky-top: rgba(249, 238, 221, 0.98);
  --season-sky-bottom: rgba(236, 219, 184, 0.92);
  --season-mist: rgba(255, 244, 224, 0.66);
  --season-sun: rgba(247, 193, 127, 0.84);
  --season-mount-back: #cfb98f;
  --season-mount-mid: #9e7f5a;
  --season-mount-front: #65482f;
  --season-water-top: rgba(132, 142, 118, 0.54);
  --season-water-bottom: rgba(101, 92, 67, 0.84);
  --season-branch: #69452e;
  --season-branch-highlight: #8e6347;
  --season-bloom: linear-gradient(135deg, rgba(241, 196, 117, 0.98), rgba(201, 123, 62, 0.94));
  --season-drift: linear-gradient(135deg, rgba(243, 208, 125, 0.94), rgba(217, 133, 70, 0.88));
}

.hero[data-season="winter"] {
  --season-accent: #55616f;
  --season-accent-strong: #7a8a99;
  --season-soft: rgba(122, 138, 153, 0.22);
  --season-sky-top: rgba(244, 242, 238, 0.98);
  --season-sky-bottom: rgba(224, 221, 212, 0.94);
  --season-mist: rgba(244, 247, 252, 0.66);
  --season-sun: rgba(223, 231, 240, 0.8);
  --season-mount-back: #c3c8c8;
  --season-mount-mid: #929999;
  --season-mount-front: #596064;
  --season-water-top: rgba(152, 166, 176, 0.5);
  --season-water-bottom: rgba(91, 103, 113, 0.82);
  --season-branch: #51463f;
  --season-branch-highlight: #73655c;
  --season-bloom: linear-gradient(135deg, rgba(251, 252, 255, 0.98), rgba(214, 223, 232, 0.94));
  --season-drift: radial-gradient(circle, rgba(255, 255, 255, 0.98), rgba(214, 223, 232, 0.92));
}

.hero__veil {
  position: absolute;
  width: 26rem;
  height: 26rem;
  border-radius: 50%;
  filter: blur(26px);
  pointer-events: none;
}

.hero__veil--a {
  left: -6rem;
  top: -10rem;
  background: radial-gradient(circle, rgba(255, 255, 255, 0.34), transparent 70%);
  animation: washFloat 16s ease-in-out infinite;
}

.hero__veil--b {
  right: -6rem;
  top: -6rem;
  background: radial-gradient(circle, rgba(240, 208, 135, 0.24), transparent 72%);
  animation: washFloat 18s ease-in-out infinite reverse;
}

.hero__particles {
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.hero__spark {
  background: radial-gradient(circle, rgba(240, 208, 135, 0.95), rgba(240, 208, 135, 0.12) 60%, transparent 78%);
  box-shadow: 0 0 0.9rem rgba(240, 208, 135, 0.35);
  animation-name: floatSpark;
  animation-iteration-count: infinite;
}

.hero__inner {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(0, 430px) minmax(0, 1fr);
  gap: 1.6rem;
  align-items: stretch;
  padding: clamp(1.3rem, 3vw, 1.8rem);
}

.hero__scroll,
.hero__scene {
  position: relative;
  min-height: 100%;
}

.hero__scroll {
  display: grid;
  gap: 1.15rem;
  padding: clamp(1.4rem, 3vw, 1.9rem);
  border-radius: 1.6rem;
  background:
    linear-gradient(180deg, rgba(255, 251, 242, 0.72), rgba(245, 235, 215, 0.56)),
    linear-gradient(90deg, rgba(157, 47, 32, 0.04), transparent 18%, transparent 82%, rgba(202, 159, 72, 0.05));
  border: 1px solid rgba(113, 79, 41, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.24);
}

.hero__scroll::before {
  content: "";
  position: absolute;
  inset: 0.7rem;
  border-radius: 1.1rem;
  border: 1px solid rgba(113, 79, 41, 0.12);
  pointer-events: none;
}

.hero__scroll-head {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
}

.hero__seal {
  width: 4.25rem;
  height: 4.25rem;
  flex: none;
  display: grid;
  place-items: center;
  border-radius: 1.1rem;
  border: 1px solid rgba(157, 47, 32, 0.38);
  background:
    radial-gradient(circle at 26% 22%, rgba(255, 255, 255, 0.36), transparent 30%),
    rgba(251, 246, 235, 0.9);
  box-shadow: inset 0 0 0 0.35rem rgba(157, 47, 32, 0.05);
  color: var(--vermillion);
  font-family: var(--font-display);
  font-size: 2rem;
  transform: rotate(-8deg);
}

.hero__titles {
  display: grid;
  gap: 0.38rem;
}

.hero__title,
.panel__title,
.trigram-showcase__title,
.qi-scroll__title,
.xiang-hall__title,
.hexagram-flow__title,
.academy__title,
.hall__title {
  margin: 0;
  font-family: var(--font-display);
  letter-spacing: 0.18rem;
  font-weight: 600;
}

.hero__eyebrow {
  margin: 0;
  color: var(--ink-soft);
  letter-spacing: 0.28rem;
  font-size: 0.96rem;
}

.hero__title {
  font-size: clamp(2.6rem, 5vw, 4.8rem);
  line-height: 0.94;
  display: inline-grid;
  gap: 0.08em;
}

.hero__title span {
  display: block;
}

.hero__subtitle {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(1.55rem, 2vw, 2rem);
  color: rgba(116, 82, 45, 0.92);
  letter-spacing: 0.22rem;
}

.hero__verses {
  display: grid;
  gap: 0.72rem;
  justify-items: center;
  text-align: center;
}

.hero__verse {
  margin: 0;
  max-width: 15em;
  color: rgba(41, 31, 22, 0.78);
  line-height: 1.9;
  opacity: 0;
  animation: revealUp 0.75s ease forwards;
  animation-delay: var(--hero-verse-delay, 0ms);
}

.hero__season-meta {
  display: grid;
  gap: 0.8rem;
  justify-items: center;
  text-align: center;
}

.hero__season-caption {
  margin: 0;
  font-family: var(--font-display);
  font-size: 1.1rem;
  letter-spacing: 0.22rem;
  color: var(--season-accent);
}

.hero__terms {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
  justify-content: center;
}

.hero__term {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.4rem 0.82rem;
  border-radius: 999px;
  border: 1px solid rgba(113, 79, 41, 0.12);
  background: rgba(255, 251, 244, 0.62);
  color: rgba(53, 38, 24, 0.76);
  font-size: 0.92rem;
  opacity: 0;
  animation: revealUp 0.75s ease forwards;
  animation-delay: var(--hero-term-delay, 0ms);
}

.hero__switch {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.72rem;
}

.hero__season-button {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  padding: 0.82rem 0.95rem;
  border-radius: 1rem;
  border: 1px solid rgba(113, 79, 41, 0.12);
  background: rgba(255, 250, 243, 0.56);
  color: var(--ink);
  box-shadow: 0 0.7rem 1.8rem rgba(67, 45, 25, 0.06);
  transition: transform 0.35s ease, border-color 0.35s ease, background 0.35s ease, box-shadow 0.35s ease, color 0.35s ease;
}

.hero__season-button:hover {
  transform: translateY(-2px);
  border-color: rgba(157, 47, 32, 0.18);
}

.hero__season-button.is-active {
  border-color: transparent;
  background:
    radial-gradient(circle at 18% 24%, rgba(255, 255, 255, 0.18), transparent 28%),
    linear-gradient(135deg, var(--season-accent), var(--season-accent-strong));
  color: #fff7eb;
  box-shadow: 0 1rem 2rem rgba(89, 58, 28, 0.16);
}

.hero__season-button-label {
  font-family: var(--font-display);
  font-size: 1.08rem;
  letter-spacing: 0.12rem;
}

.hero__season-button-note {
  font-size: 0.88rem;
  opacity: 0.76;
}

.hero__season-button.is-active .hero__season-button-note {
  opacity: 0.92;
}

.hero__menu {
  display: flex;
  gap: 0.75rem;
  flex-wrap: wrap;
  margin-top: auto;
}

.hero__link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 7rem;
  padding: 0.78rem 1.25rem;
  border-radius: 999px;
  background: rgba(157, 47, 32, 0.05);
  border: 1px solid rgba(157, 47, 32, 0.12);
  color: var(--season-accent);
  transition: transform 0.35s ease, background 0.35s ease, border-color 0.35s ease;
}

.hero__link:hover {
  transform: translateY(-2px);
  background: rgba(157, 47, 32, 0.1);
  border-color: rgba(157, 47, 32, 0.18);
}

.hero__link.is-active {
  background:
    radial-gradient(circle at 18% 24%, rgba(255, 255, 255, 0.16), transparent 28%),
    linear-gradient(135deg, rgba(157, 47, 32, 0.92), rgba(128, 31, 21, 0.9));
  border-color: transparent;
  color: #fff7eb;
  box-shadow: 0 1rem 2rem rgba(128, 31, 21, 0.14);
}

.hero__scene {
  overflow: hidden;
  border-radius: 1.8rem;
  padding: 1rem;
  border: 1px solid rgba(113, 79, 41, 0.12);
  background:
    radial-gradient(circle at 18% 16%, rgba(255, 255, 255, 0.2), transparent 18%),
    linear-gradient(180deg, rgba(255, 252, 246, 0.54), rgba(239, 228, 205, 0.48));
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.26);
}

.hero__scene::before {
  content: "";
  position: absolute;
  inset: 1rem;
  border-radius: 1.35rem;
  background:
    radial-gradient(circle at 88% 14%, rgba(255, 255, 255, 0.24), transparent 20%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.08), transparent 24%, transparent 76%, rgba(202, 159, 72, 0.05));
  pointer-events: none;
}

.hero__painting {
  position: absolute;
  inset: 1rem 1rem 6rem;
  overflow: hidden;
  border-radius: 1.45rem;
  border: 1px solid rgba(126, 83, 46, 0.12);
  background: linear-gradient(180deg, var(--season-sky-top), var(--season-sky-bottom));
  box-shadow: inset 0 0 2.6rem rgba(255, 255, 255, 0.22);
}

.hero__painting::before,
.hero__painting::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.hero__painting::before {
  background:
    radial-gradient(circle at 22% 14%, rgba(255, 255, 255, 0.5), transparent 20%),
    radial-gradient(circle at 82% 18%, var(--season-soft), transparent 20%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.12), transparent 26%, transparent 72%, rgba(60, 45, 28, 0.08));
}

.hero__painting::after {
  background: linear-gradient(90deg, rgba(94, 67, 39, 0.06), transparent 12%, transparent 88%, rgba(94, 67, 39, 0.06));
  opacity: 0.5;
}

.hero__sun {
  position: absolute;
  top: 10%;
  right: 12%;
  width: 8rem;
  aspect-ratio: 1;
  border-radius: 50%;
  background:
    radial-gradient(circle at 30% 30%, rgba(255, 255, 255, 0.82), transparent 28%),
    radial-gradient(circle, var(--season-sun), transparent 72%);
  box-shadow: 0 0 2.8rem var(--season-soft);
  animation: heroScenePulse 8s ease-in-out infinite;
}

.hero__mist {
  position: absolute;
  border-radius: 50%;
  filter: blur(20px);
  background: radial-gradient(circle, var(--season-mist), transparent 70%);
}

.hero__mist--back {
  width: 28rem;
  height: 12rem;
  left: 9%;
  top: 17%;
  opacity: 0.72;
  animation: heroSceneDrift 16s ease-in-out infinite;
}

.hero__mist--front {
  width: 24rem;
  height: 10rem;
  right: 16%;
  bottom: 20%;
  opacity: 0.46;
  animation: heroSceneDrift 19s ease-in-out infinite reverse;
}

.hero__mount {
  position: absolute;
  bottom: 24%;
  clip-path: polygon(0 100%, 8% 70%, 18% 58%, 34% 24%, 47% 62%, 59% 32%, 72% 58%, 86% 38%, 100% 100%);
}

.hero__mount--far {
  left: -4%;
  width: 70%;
  height: 42%;
  background: linear-gradient(180deg, var(--season-mount-back), rgba(129, 112, 85, 0.22));
  opacity: 0.36;
}

.hero__mount--mid {
  left: 14%;
  width: 60%;
  height: 36%;
  background: linear-gradient(180deg, var(--season-mount-mid), rgba(96, 74, 51, 0.54));
  opacity: 0.62;
}

.hero__mount--near {
  right: -6%;
  width: 58%;
  height: 34%;
  background: linear-gradient(180deg, var(--season-mount-front), rgba(53, 40, 27, 0.76));
  opacity: 0.84;
}

.hero__water {
  position: absolute;
  inset: auto 0 0;
  height: 36%;
  background: linear-gradient(180deg, var(--season-water-top), var(--season-water-bottom));
  clip-path: polygon(0 18%, 12% 13%, 23% 18%, 36% 10%, 49% 14%, 62% 12%, 74% 18%, 87% 12%, 100% 16%, 100% 100%, 0 100%);
}

.hero__water::before {
  content: "";
  position: absolute;
  left: 10%;
  right: 12%;
  top: 18%;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.5), transparent);
  box-shadow:
    0 1rem 0 rgba(255, 255, 255, 0.22),
    0 2rem 0 rgba(255, 255, 255, 0.12);
}

.hero__ripple {
  position: absolute;
  left: var(--ripple-x);
  bottom: var(--ripple-y);
  width: var(--ripple-w);
  height: 0.75rem;
  border-radius: 50%;
  border: 1px solid rgba(255, 255, 255, 0.32);
  border-top-color: transparent;
  border-left-color: transparent;
  opacity: 0.76;
  animation: heroWaterFlow var(--ripple-duration) ease-in-out infinite;
}

.hero__ripple--a {
  --ripple-x: 16%;
  --ripple-y: 22%;
  --ripple-w: 7rem;
  --ripple-duration: 6.5s;
}

.hero__ripple--b {
  --ripple-x: 44%;
  --ripple-y: 28%;
  --ripple-w: 6rem;
  --ripple-duration: 5.8s;
}

.hero__ripple--c {
  --ripple-x: 72%;
  --ripple-y: 20%;
  --ripple-w: 7.5rem;
  --ripple-duration: 7.1s;
}

.hero__islet {
  position: absolute;
  right: 17%;
  bottom: 18%;
  width: 13rem;
  height: 4.8rem;
  background: linear-gradient(180deg, rgba(119, 98, 72, 0.72), rgba(73, 57, 40, 0.94));
  clip-path: ellipse(52% 44% at 50% 50%);
  opacity: 0.56;
}

.hero__bridge {
  position: absolute;
  left: 42%;
  bottom: 21%;
  width: 11.5rem;
  height: 2.2rem;
  border-top: 2px solid rgba(84, 58, 33, 0.56);
  border-radius: 50% 50% 0 0 / 100% 100% 0 0;
  transform: skewX(-18deg);
  opacity: 0.76;
}

.hero__bridge::before {
  content: "";
  position: absolute;
  left: 10%;
  right: 10%;
  top: 0.95rem;
  border-top: 1px solid rgba(84, 58, 33, 0.34);
}

.hero__pavilion {
  position: absolute;
  right: 20.5%;
  bottom: 23.5%;
  width: 7.6rem;
  height: 5rem;
}

.hero__pavilion-roof,
.hero__pavilion-body,
.hero__pavilion-pillar {
  position: absolute;
}

.hero__pavilion-roof {
  inset: 0.15rem 0 auto;
  height: 1.2rem;
  background: linear-gradient(180deg, rgba(124, 48, 33, 0.92), rgba(83, 24, 16, 0.96));
  clip-path: polygon(4% 100%, 10% 28%, 24% 8%, 50% 0, 76% 8%, 90% 28%, 96% 100%);
  box-shadow: 0 0.25rem 0.75rem rgba(76, 22, 16, 0.18);
}

.hero__pavilion-body {
  left: 0.7rem;
  right: 0.7rem;
  top: 1.25rem;
  bottom: 0.65rem;
  border: 1px solid rgba(95, 68, 40, 0.16);
  background: linear-gradient(180deg, rgba(247, 236, 208, 0.9), rgba(212, 178, 120, 0.84));
}

.hero__pavilion-pillar {
  width: 0.18rem;
  top: 1.3rem;
  bottom: 0.68rem;
  background: rgba(98, 67, 37, 0.72);
}

.hero__pavilion-pillar--a { left: 1.35rem; }
.hero__pavilion-pillar--b { left: 50%; translate: -50% 0; }
.hero__pavilion-pillar--c { right: 1.35rem; }

.hero__branch {
  position: absolute;
  left: -2%;
  top: -2%;
  width: 42%;
  height: 36%;
  transform-origin: left top;
  animation: heroBranchSway 7s ease-in-out infinite;
}

.hero__branch-line {
  position: absolute;
  border-radius: 999px;
  background: linear-gradient(180deg, var(--season-branch-highlight), var(--season-branch));
  box-shadow: 0 0.25rem 0.7rem rgba(53, 34, 16, 0.14);
}

.hero__branch-line--a {
  width: 58%;
  height: 0.46rem;
  left: 0;
  top: 24%;
  transform: rotate(14deg);
}

.hero__branch-line--b {
  width: 32%;
  height: 0.34rem;
  left: 30%;
  top: 14%;
  transform: rotate(-22deg);
}

.hero__branch-line--c {
  width: 26%;
  height: 0.32rem;
  left: 26%;
  top: 36%;
  transform: rotate(34deg);
}

.hero__blossom {
  position: absolute;
  left: var(--bloom-x);
  top: var(--bloom-y);
  width: 1.05rem;
  height: 1.05rem;
  border-radius: 42% 58% 46% 54%;
  background:
    radial-gradient(circle at 35% 35%, rgba(255, 255, 255, 0.94), transparent 28%),
    var(--season-bloom);
  box-shadow: 0 0 0.9rem var(--season-soft);
  transform: translate(-50%, -50%) rotate(var(--bloom-rotate));
}

.hero__blossom--1 { --bloom-x: 18%; --bloom-y: 22%; --bloom-rotate: -18deg; }
.hero__blossom--2 { --bloom-x: 28%; --bloom-y: 19%; --bloom-rotate: 16deg; }
.hero__blossom--3 { --bloom-x: 32%; --bloom-y: 31%; --bloom-rotate: -12deg; }
.hero__blossom--4 { --bloom-x: 44%; --bloom-y: 14%; --bloom-rotate: 22deg; }
.hero__blossom--5 { --bloom-x: 47%; --bloom-y: 24%; --bloom-rotate: -10deg; }
.hero__blossom--6 { --bloom-x: 56%; --bloom-y: 11%; --bloom-rotate: 30deg; }
.hero__blossom--7 { --bloom-x: 38%; --bloom-y: 39%; --bloom-rotate: 8deg; }

.hero[data-season="summer"] .hero__blossom {
  width: 1.2rem;
  height: 0.78rem;
  border-radius: 62% 38% 58% 42%;
}

.hero[data-season="autumn"] .hero__blossom {
  width: 0.92rem;
  height: 1.18rem;
  border-radius: 44% 56% 58% 42%;
}

.hero[data-season="winter"] .hero__blossom {
  width: 0.84rem;
  height: 0.84rem;
  border-radius: 50%;
}

.hero__birds,
.hero__drifts {
  position: absolute;
  inset: 0;
}

.hero__bird {
  position: absolute;
  width: 2.2rem;
  height: 1rem;
  border-top: 2px solid rgba(79, 57, 35, 0.58);
  border-radius: 100% 100% 0 0;
  animation: heroBirdArc 12s linear infinite;
  opacity: 0.78;
}

.hero__bird::after {
  content: "";
  position: absolute;
  right: -1.25rem;
  top: -2px;
  width: 2.2rem;
  height: 1rem;
  border-top: 2px solid rgba(79, 57, 35, 0.58);
  border-radius: 100% 100% 0 0;
  transform: scaleX(-1);
}

.hero__bird--a { top: 18%; right: 26%; animation-delay: -2s; }
.hero__bird--b { top: 24%; right: 34%; transform: scale(0.9); animation-delay: -7s; }
.hero__bird--c { top: 16%; right: 18%; transform: scale(0.72); animation-delay: -4s; }

.hero[data-season="winter"] .hero__bird {
  opacity: 0.46;
}

.hero__drift {
  position: absolute;
  left: var(--drift-x);
  top: -8%;
  width: 0.98rem;
  height: 0.8rem;
  border-radius: 60% 40% 56% 44%;
  background: var(--season-drift);
  box-shadow: 0 0.35rem 0.8rem rgba(83, 58, 33, 0.12);
  opacity: 0.78;
  animation: heroSeasonFall var(--drift-duration) linear infinite;
  animation-delay: var(--drift-delay);
}

.hero__drift--1 { --drift-x: 14%; --drift-duration: 10.6s; --drift-delay: -2.8s; }
.hero__drift--2 { --drift-x: 28%; --drift-duration: 12.4s; --drift-delay: -7.1s; }
.hero__drift--3 { --drift-x: 46%; --drift-duration: 9.8s; --drift-delay: -4.2s; }
.hero__drift--4 { --drift-x: 62%; --drift-duration: 11.2s; --drift-delay: -1.4s; }
.hero__drift--5 { --drift-x: 78%; --drift-duration: 12.8s; --drift-delay: -6.3s; }
.hero__drift--6 { --drift-x: 88%; --drift-duration: 10.1s; --drift-delay: -8.6s; }

.hero[data-season="summer"] .hero__drift {
  width: 0.94rem;
  height: 1.16rem;
  border-radius: 44% 56% 62% 38%;
}

.hero[data-season="winter"] .hero__drift {
  width: 0.56rem;
  height: 0.56rem;
  border-radius: 50%;
  box-shadow: 0 0 0.9rem rgba(255, 255, 255, 0.28);
}

.hero__inscription {
  position: absolute;
  right: 4%;
  top: 10%;
  writing-mode: vertical-rl;
  text-orientation: mixed;
  padding: 0.8rem 0.38rem;
  border-left: 1px solid rgba(113, 79, 41, 0.16);
  border-right: 1px solid rgba(113, 79, 41, 0.12);
  color: rgba(79, 57, 35, 0.72);
  font-family: var(--font-display);
  letter-spacing: 0.2rem;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.34), rgba(255, 255, 255, 0));
}

.hero__legend {
  position: absolute;
  left: 1rem;
  right: 1rem;
  bottom: 1rem;
  z-index: 1;
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 1rem;
  padding: 1rem 1.15rem;
  border-radius: 1.15rem;
  border: 1px solid rgba(113, 79, 41, 0.12);
  background: linear-gradient(180deg, rgba(255, 251, 245, 0.84), rgba(246, 237, 219, 0.78));
  box-shadow: 0 0.85rem 1.8rem rgba(53, 34, 16, 0.08);
}

.hero__legend-label {
  margin: 0;
  color: var(--ink-soft);
  letter-spacing: 0.22rem;
}

.hero__legend-title {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(1.6rem, 2.3vw, 2.35rem);
  letter-spacing: 0.12rem;
}

.hero__legend-text {
  margin: 0;
  max-width: 26rem;
  color: rgba(41, 31, 22, 0.72);
  line-height: 1.8;
  text-align: right;
}

.bagua-orbit {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  animation: spinSlow 36s linear infinite;
}

.bagua-orbit--intro { width: min(78vw, 700px); height: min(78vw, 700px); }

.bagua-orbit__char {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 2.2rem;
  height: 2.2rem;
  margin: -1.1rem;
  display: grid;
  place-items: center;
  border-radius: 50%;
  color: rgba(41, 31, 22, 0.76);
  background: rgba(252, 248, 239, 0.55);
  border: 1px solid rgba(132, 97, 53, 0.14);
  font-family: var(--font-display);
}

.bagua-orbit__char:nth-child(1) { transform: rotate(0deg) translateY(-15rem) rotate(0deg); }
.bagua-orbit__char:nth-child(2) { transform: rotate(45deg) translateY(-15rem) rotate(-45deg); }
.bagua-orbit__char:nth-child(3) { transform: rotate(90deg) translateY(-15rem) rotate(-90deg); }
.bagua-orbit__char:nth-child(4) { transform: rotate(135deg) translateY(-15rem) rotate(-135deg); }
.bagua-orbit__char:nth-child(5) { transform: rotate(180deg) translateY(-15rem) rotate(-180deg); }
.bagua-orbit__char:nth-child(6) { transform: rotate(225deg) translateY(-15rem) rotate(-225deg); }
.bagua-orbit__char:nth-child(7) { transform: rotate(270deg) translateY(-15rem) rotate(-270deg); }
.bagua-orbit__char:nth-child(8) { transform: rotate(315deg) translateY(-15rem) rotate(-315deg); }

.panel,
.trigram-showcase,
.season-compass,
.daoyi-hall,
.culture-hall,
.xiang-hall,
.hexagram-flow,
.game-lab,
.academy,
.hall {
  margin-top: 1.6rem;
  border-radius: 1.6rem;
  padding: clamp(1.2rem, 3vw, 2rem);
}

.panel__head,
.trigram-showcase__head,
.season-compass__head,
.heluo-atlas__head,
.daoyi-hall__head,
.culture-hall__head,
.xiang-hall__head,
.hexagram-flow__head,
.game-lab__head,
.academy__head,
.hall__head {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
  margin-bottom: 1rem;
}

.panel__title,
.trigram-showcase__title,
.heluo-atlas__title,
.daoyi-hall__title,
.culture-hall__title,
.xiang-hall__title,
.hexagram-flow__title,
.game-lab__title,
.academy__title,
.hall__title { font-size: clamp(1.55rem, 2.8vw, 2.2rem); }

.game-lab {
  isolation: isolate;
}

.game-lab__mist {
  position: absolute;
  width: 24rem;
  height: 24rem;
  border-radius: 50%;
  filter: blur(24px);
  opacity: 0.42;
  pointer-events: none;
}

.game-lab__mist--a {
  left: -7rem;
  top: -6rem;
  background: radial-gradient(circle, rgba(255, 255, 255, 0.42), transparent 72%);
  animation: washFloat 15s ease-in-out infinite;
}

.game-lab__mist--b {
  right: -7rem;
  bottom: -8rem;
  background: radial-gradient(circle, rgba(240, 208, 135, 0.24), transparent 72%);
  animation: washFloat 19s ease-in-out infinite reverse;
}

.game-lab__heading {
  display: flex;
  align-items: center;
  gap: 1rem;
  flex-wrap: wrap;
}

.game-lab__seal {
  width: 3.5rem;
  height: 3.5rem;
  display: grid;
  place-items: center;
  border: 1px solid rgba(157, 47, 32, 0.6);
  color: var(--vermillion);
  font-family: var(--font-display);
  font-size: 1.6rem;
  transform: rotate(-8deg);
  box-shadow: inset 0 0 0 0.28rem rgba(157, 47, 32, 0.06);
}

.game-lab__titles {
  display: grid;
  gap: 0.32rem;
}

.game-lab__label {
  margin: 0;
  color: var(--ink-soft);
  letter-spacing: 0.2rem;
}

.game-lab__body {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(280px, 360px) minmax(0, 1fr);
  gap: 1.2rem;
  align-items: start;
}

.game-lab__sidebar {
  display: grid;
  gap: 1rem;
}

.game-realm-switch {
  display: grid;
  gap: 0.75rem;
}

.game-realm-button {
  appearance: none;
  border: 1px solid rgba(126, 90, 55, 0.14);
  border-radius: 1.2rem;
  background: rgba(255, 251, 243, 0.82);
  display: flex;
  align-items: center;
  gap: 0.85rem;
  padding: 0.9rem 1rem;
  transition: transform 0.24s ease, border-color 0.24s ease, box-shadow 0.24s ease;
}

.game-realm-button:hover {
  transform: translateY(-2px);
  border-color: rgba(202, 159, 72, 0.42);
  box-shadow: 0 0.9rem 1.6rem rgba(60, 40, 22, 0.08);
}

.game-realm-button.is-active {
  border-color: rgba(157, 47, 32, 0.2);
  background:
    radial-gradient(circle at 84% 18%, rgba(255, 250, 238, 0.16), transparent 22%),
    linear-gradient(135deg, rgba(157, 47, 32, 0.94), rgba(120, 33, 21, 0.98));
  box-shadow: 0 1.2rem 2.2rem rgba(60, 40, 22, 0.12);
}

.game-realm-button__seal {
  width: 3rem;
  aspect-ratio: 1;
  display: grid;
  place-items: center;
  border-radius: 0.95rem;
  border: 1px solid rgba(157, 47, 32, 0.24);
  background: rgba(157, 47, 32, 0.08);
  color: var(--vermillion);
  font-family: var(--font-display);
  font-size: 1.35rem;
  transform: rotate(-6deg);
}

.game-realm-button.is-active .game-realm-button__seal {
  background: rgba(255, 248, 236, 0.14);
  border-color: rgba(255, 232, 200, 0.24);
  color: rgba(255, 242, 216, 0.92);
}

.game-realm-button__copy {
  display: grid;
  gap: 0.12rem;
  text-align: left;
}

.game-realm-button__label {
  color: var(--ink-soft);
  letter-spacing: 0.14rem;
}

.game-realm-button__title {
  font-family: var(--font-display);
  font-size: 1.25rem;
}

.game-realm-button.is-active .game-realm-button__label,
.game-realm-button.is-active .game-realm-button__title {
  color: rgba(255, 245, 230, 0.96);
}

.game-scroll,
.game-stage-card,
.game-board,
.game-feedback__card,
.game-reward__card {
  border: 1px solid rgba(126, 90, 55, 0.14);
  background: linear-gradient(180deg, rgba(255, 251, 243, 0.92), rgba(246, 238, 222, 0.88));
  box-shadow: 0 1rem 2.2rem rgba(60, 40, 22, 0.08);
}

.game-scroll {
  position: relative;
  padding: 1.2rem 1.2rem 1.25rem;
  border-radius: 1.35rem;
  overflow: hidden;
}

.game-scroll::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(135deg, rgba(157, 47, 32, 0.04), transparent 32%),
    radial-gradient(circle at 82% 14%, rgba(202, 159, 72, 0.12), transparent 20%);
  pointer-events: none;
}

.game-scroll__label,
.game-board__chapter,
.game-board__setting {
  margin: 0;
  color: var(--ink-soft);
  letter-spacing: 0.18rem;
}

.game-scroll__title,
.game-board__title,
.game-reward__title {
  margin: 0.35rem 0 0;
  font-family: var(--font-display);
}

.game-scroll__title {
  font-size: clamp(1.8rem, 3vw, 2.4rem);
}

.game-scroll__subtitle,
.game-board__subtitle {
  margin: 0.45rem 0 0;
  color: rgba(41, 31, 22, 0.78);
}

.game-scroll__prologue {
  display: grid;
  gap: 0.7rem;
  margin-top: 1rem;
}

.game-scroll__actions {
  display: flex;
  margin-top: 1rem;
}

.game-scroll__button {
  width: 100%;
  justify-content: center;
}

.game-scroll__text {
  margin: 0;
  line-height: 1.85;
  color: rgba(27, 21, 16, 0.84);
  opacity: 0;
  transform: translateY(10px);
  animation: fadeSlide 0.55s ease forwards;
  animation-delay: var(--game-prologue-delay, 0ms);
}

.game-stage-rail {
  display: grid;
  gap: 0.9rem;
}

.game-stage-card {
  position: relative;
  padding: 1rem 1.05rem;
  border-radius: 1.2rem;
  text-align: left;
  transition: transform 0.35s ease, border-color 0.35s ease, background 0.35s ease, box-shadow 0.35s ease;
}

.game-stage-card:hover {
  transform: translateY(-2px);
}

.game-stage-card.is-active {
  border-color: rgba(202, 159, 72, 0.32);
  box-shadow: 0 1.2rem 2.4rem rgba(60, 40, 22, 0.12), 0 0 0 1px rgba(202, 159, 72, 0.1);
  background:
    radial-gradient(circle at 90% 12%, rgba(255, 255, 255, 0.16), transparent 20%),
    linear-gradient(135deg, rgba(157, 47, 32, 0.92), rgba(119, 29, 21, 0.96));
  color: #fff5e8;
}

.game-stage-card.is-pending {
  opacity: 0.92;
}

.game-stage-card.is-awakened {
  border-style: dashed;
}

.game-stage-card.is-cleared {
  border-color: rgba(202, 159, 72, 0.24);
  background:
    radial-gradient(circle at 88% 18%, rgba(240, 208, 135, 0.14), transparent 18%),
    linear-gradient(180deg, rgba(255, 251, 243, 0.92), rgba(246, 238, 222, 0.88));
}

.game-stage-card__chapter,
.game-stage-card__subtitle,
.game-stage-card__status,
.game-board__line,
.game-feedback__title,
.game-reward__label,
.game-reward__text {
  margin: 0;
  color: var(--ink-soft);
}

.game-stage-card__title {
  margin: 0.35rem 0 0;
  font-family: var(--font-display);
  font-size: 1.3rem;
}

.game-stage-card__subtitle {
  margin-top: 0.35rem;
  line-height: 1.7;
}

.game-stage-card__status {
  display: inline-flex;
  margin-top: 0.8rem;
  padding: 0.28rem 0.6rem;
  border-radius: 999px;
  border: 1px solid rgba(126, 90, 55, 0.12);
  background: rgba(255, 255, 255, 0.36);
  font-size: 0.82rem;
  letter-spacing: 0.12rem;
}

.game-stage-card.is-active .game-stage-card__chapter,
.game-stage-card.is-active .game-stage-card__subtitle,
.game-stage-card.is-active .game-stage-card__status {
  color: rgba(255, 245, 232, 0.86);
}

.game-stage-card.is-active .game-stage-card__status {
  border-color: rgba(255, 245, 232, 0.18);
  background: rgba(255, 255, 255, 0.08);
}

.game-board {
  position: relative;
  padding: 1.2rem;
  border-radius: 1.55rem;
  overflow: hidden;
}

.game-board::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 16% 14%, rgba(255, 255, 255, 0.2), transparent 18%),
    linear-gradient(135deg, rgba(157, 47, 32, 0.04), transparent 34%);
  pointer-events: none;
}

.game-board__head,
.game-board__footer {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
}

.game-board__title {
  font-size: clamp(1.75rem, 3vw, 2.35rem);
}

.game-board__progress {
  min-width: min(100%, 19rem);
  display: grid;
  gap: 0.7rem;
}

.game-board__progress-track {
  height: 0.65rem;
  border-radius: 999px;
  background: rgba(202, 159, 72, 0.14);
  overflow: hidden;
}

.game-board__progress-fill {
  display: block;
  width: 0;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, rgba(166, 46, 35, 0.96), rgba(240, 208, 135, 0.96));
  transition: width 0.45s ease;
}

.game-board__stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.75rem;
}

.game-board__stat {
  display: grid;
  gap: 0.18rem;
  padding: 0.7rem 0.8rem;
  border-radius: 1rem;
  background: rgba(255, 250, 243, 0.66);
  border: 1px solid rgba(126, 90, 55, 0.12);
}

.game-board__stat strong {
  font-family: var(--font-display);
  font-size: 1.15rem;
  color: rgba(39, 25, 15, 0.92);
  font-weight: 600;
}

.game-board__stat em {
  color: var(--ink-soft);
  font-style: normal;
  letter-spacing: 0.14rem;
}

.game-board__invocation {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 0.45rem;
  margin-top: 1rem;
}

.game-board__line {
  line-height: 1.8;
}

.game-board__arena {
  position: relative;
  z-index: 1;
  margin-top: 1rem;
}

.game-stage-view {
  display: none;
}

.game-board[data-stage="yin-yang"] .game-stage-view--yin-yang,
.game-board[data-stage="bagua-form"] .game-stage-view--bagua-form,
.game-board[data-stage="bagua-scene"] .game-stage-view--bagua-scene,
.game-board[data-stage="compose-upper-lower"] .game-stage-view--compose,
.game-board[data-stage="trace-hexagram-name"] .game-stage-view--hexagram-name,
.game-board[data-stage="match-sixtyfour"] .game-stage-view--hexagram-name,
.game-board[data-stage="reflect-know-change"] .game-stage-view--reflect,
.game-board[data-stage="rise-six-lines"] .game-stage-view--rise,
.game-board[data-stage="split-threads"] .game-stage-view--questioning,
.game-board[data-stage="question-gates"] .game-stage-view--questioning,
.game-board[data-stage="time-boundary"] .game-stage-view--questioning,
.game-board[data-stage="forge-poster"] .game-stage-view--questioning,
.game-board[data-stage="cast-set-time"] .game-stage-view--questioning,
.game-board[data-stage="cast-form-hexagram"] .game-stage-view--questioning,
.game-board[data-stage="cast-moving-post"] .game-stage-view--questioning,
.game-board[data-stage="body-use-place"] .game-stage-view--questioning,
.game-board[data-stage="body-use-relation"] .game-stage-view--questioning,
.game-board[data-stage="body-use-balance"] .game-stage-view--questioning,
.game-board[data-stage="line-direction"] .game-stage-view--questioning,
.game-board[data-stage="mutual-change-trend"] .game-stage-view--questioning,
.game-board[data-stage="response-timing"] .game-stage-view--questioning,
.game-board[data-stage="duanji-poster"] .game-stage-view--questioning {
  display: block;
}

.game-yinyang {
  display: grid;
  grid-template-columns: minmax(160px, 1fr) minmax(0, 1.45fr) minmax(160px, 1fr);
  gap: 1rem;
  align-items: stretch;
}

.game-yinyang__zone,
.game-yinyang__action {
  appearance: none;
  border: 1px solid rgba(126, 90, 55, 0.14);
}

.game-yinyang__zone {
  position: relative;
  min-height: 22rem;
  border-radius: 1.4rem;
  display: grid;
  align-content: end;
  justify-items: center;
  gap: 0.5rem;
  padding: 1.2rem;
  overflow: hidden;
  transition: transform 0.35s ease, border-color 0.35s ease, box-shadow 0.35s ease;
}

.game-yinyang__zone::before,
.game-yinyang__zone::after {
  content: "";
  position: absolute;
  pointer-events: none;
}

.game-yinyang__zone::before {
  inset: 0;
}

.game-yinyang__zone::after {
  left: 50%;
  top: 14%;
  width: 7rem;
  height: 7rem;
  border-radius: 50%;
  translate: -50% 0;
  filter: blur(2px);
}

.game-yinyang__zone--yin {
  background:
    linear-gradient(180deg, rgba(45, 47, 63, 0.96), rgba(31, 34, 47, 0.98)),
    linear-gradient(180deg, rgba(255, 255, 255, 0.05), transparent);
}

.game-yinyang__zone--yin::before {
  background:
    radial-gradient(circle at 50% 16%, rgba(255, 255, 255, 0.12), transparent 20%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.06), transparent 34%),
    linear-gradient(0deg, rgba(255, 255, 255, 0.04), transparent 24%);
}

.game-yinyang__zone--yin::after {
  background: radial-gradient(circle, rgba(174, 198, 214, 0.3), transparent 72%);
}

.game-yinyang__zone--yang {
  background:
    linear-gradient(180deg, rgba(194, 138, 63, 0.96), rgba(156, 100, 39, 0.98)),
    linear-gradient(180deg, rgba(255, 255, 255, 0.08), transparent);
}

.game-yinyang__zone--yang::before {
  background:
    radial-gradient(circle at 50% 16%, rgba(255, 250, 231, 0.2), transparent 20%),
    linear-gradient(180deg, rgba(255, 250, 231, 0.08), transparent 34%),
    linear-gradient(0deg, rgba(255, 250, 231, 0.05), transparent 24%);
}

.game-yinyang__zone--yang::after {
  background: radial-gradient(circle, rgba(255, 237, 185, 0.48), transparent 72%);
}

.game-yinyang__zone.is-target {
  transform: translateY(-4px);
  border-color: rgba(240, 208, 135, 0.56);
  box-shadow: 0 1.4rem 2.2rem rgba(60, 40, 22, 0.14), 0 0 0 1px rgba(255, 255, 255, 0.08);
}

.game-yinyang__zone-seal {
  position: relative;
  z-index: 1;
  font-family: var(--font-display);
  font-size: 2rem;
  color: rgba(255, 245, 232, 0.96);
}

.game-yinyang__zone-text {
  position: relative;
  z-index: 1;
  color: rgba(255, 245, 232, 0.8);
  letter-spacing: 0.2rem;
}

.game-yinyang__mirror {
  position: relative;
  min-height: 22rem;
  border-radius: 1.8rem;
  overflow: hidden;
  display: grid;
  place-items: center;
  background:
    radial-gradient(circle at center, rgba(255, 252, 245, 0.94), rgba(247, 238, 216, 0.92) 54%, rgba(233, 218, 181, 0.88) 100%);
  border: 1px solid rgba(126, 90, 55, 0.16);
  box-shadow: inset 0 0 2.8rem rgba(255, 255, 255, 0.34);
}

.game-yinyang__mirror-ring {
  position: absolute;
  inset: 50%;
  translate: -50% -50%;
  border-radius: 50%;
  border: 1px solid rgba(202, 159, 72, 0.18);
  pointer-events: none;
}

.game-yinyang__mirror-ring--a {
  width: 78%;
  aspect-ratio: 1;
  animation: spinSlow 30s linear infinite;
}

.game-yinyang__mirror-ring--b {
  width: 56%;
  aspect-ratio: 1;
  border-style: dashed;
  animation: spinSlow 18s linear infinite reverse;
}

.game-yinyang__mirror-core {
  position: relative;
  z-index: 1;
  width: min(100%, 26rem);
  display: grid;
  gap: 0.85rem;
  justify-items: center;
}

.game-yinyang__prompt {
  margin: 0;
  color: var(--ink-soft);
  letter-spacing: 0.2rem;
}

.game-yinyang__card-slot {
  width: min(100%, 21rem);
  min-height: 14rem;
  display: grid;
  place-items: center;
}

.game-card {
  width: min(100%, 18rem);
  min-height: 13rem;
  padding: 1.2rem 1.1rem;
  border-radius: 1.35rem;
  display: grid;
  align-content: center;
  gap: 0.55rem;
  text-align: center;
  border: 1px solid rgba(126, 90, 55, 0.14);
  background:
    radial-gradient(circle at 24% 18%, rgba(255, 255, 255, 0.42), transparent 22%),
    linear-gradient(180deg, rgba(255, 252, 246, 0.96), rgba(246, 238, 220, 0.9));
  box-shadow: 0 1.2rem 2rem rgba(60, 40, 22, 0.08);
  cursor: grab;
  user-select: none;
  touch-action: none;
  transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.game-card[data-category="自然景象"] {
  background:
    radial-gradient(circle at 24% 18%, rgba(255, 255, 255, 0.42), transparent 22%),
    linear-gradient(180deg, rgba(248, 251, 255, 0.96), rgba(236, 241, 247, 0.92));
}

.game-card[data-category="行为状态"] {
  background:
    radial-gradient(circle at 24% 18%, rgba(255, 255, 255, 0.42), transparent 22%),
    linear-gradient(180deg, rgba(255, 248, 242, 0.96), rgba(246, 236, 224, 0.92));
}

.game-card[data-category="情绪气息"] {
  background:
    radial-gradient(circle at 24% 18%, rgba(255, 255, 255, 0.42), transparent 22%),
    linear-gradient(180deg, rgba(251, 245, 250, 0.96), rgba(242, 232, 241, 0.92));
}

.game-card[data-category="声气情境"] {
  background:
    radial-gradient(circle at 24% 18%, rgba(255, 255, 255, 0.42), transparent 22%),
    linear-gradient(180deg, rgba(255, 249, 238, 0.96), rgba(246, 237, 214, 0.92));
}

.game-card[data-edge="true"] {
  border-style: dashed;
  box-shadow: 0 1.2rem 2rem rgba(60, 40, 22, 0.08), 0 0 0 1px rgba(202, 159, 72, 0.08);
}

.game-card.is-dragging {
  cursor: grabbing;
  box-shadow: 0 1.6rem 2.8rem rgba(60, 40, 22, 0.16);
}

.game-card__category {
  margin: 0;
  color: var(--ink-soft);
  letter-spacing: 0.2rem;
}

.game-card__title,
.game-feedback__phrase {
  margin: 0;
  font-family: var(--font-display);
}

.game-card__title {
  font-size: clamp(2rem, 3.5vw, 2.8rem);
  line-height: 1.05;
}

.game-card__hint,
.game-feedback__note {
  margin: 0;
  color: rgba(41, 31, 22, 0.76);
  line-height: 1.8;
}

.game-yinyang__actions {
  display: flex;
  justify-content: center;
  gap: 0.9rem;
  margin-top: 1rem;
}

.game-yinyang__action {
  min-width: 8rem;
  padding: 0.82rem 1.3rem;
  border-radius: 999px;
  color: #fff6eb;
  box-shadow: 0 1rem 1.8rem rgba(60, 40, 22, 0.12);
  transition: transform 0.35s ease, opacity 0.35s ease, box-shadow 0.35s ease;
}

.game-yinyang__action:hover:not(:disabled) {
  transform: translateY(-2px);
}

.game-yinyang__action:disabled,
.panel__button:disabled {
  opacity: 0.62;
  cursor: not-allowed;
  box-shadow: none;
}

.game-yinyang__action--yin {
  background: linear-gradient(135deg, rgba(46, 49, 68, 0.96), rgba(31, 34, 47, 0.98));
}

.game-yinyang__action--yang {
  background: linear-gradient(135deg, rgba(180, 124, 52, 0.96), rgba(149, 92, 34, 0.98));
}

.game-feedback {
  position: relative;
  z-index: 1;
  margin-top: 1rem;
}

.game-feedback__card {
  padding: 1rem 1.05rem;
  border-radius: 1.15rem;
}

.game-feedback__card.is-correct {
  background:
    radial-gradient(circle at 88% 16%, rgba(240, 208, 135, 0.18), transparent 18%),
    linear-gradient(180deg, rgba(255, 251, 243, 0.94), rgba(247, 239, 221, 0.9));
}

.game-feedback__card.is-wrong {
  background:
    radial-gradient(circle at 88% 16%, rgba(157, 47, 32, 0.08), transparent 18%),
    linear-gradient(180deg, rgba(255, 251, 243, 0.94), rgba(244, 233, 217, 0.9));
}

.game-feedback__phrase {
  margin-top: 0.35rem;
  font-size: clamp(1.35rem, 2.2vw, 1.8rem);
}

.game-feedback__note {
  margin-top: 0.45rem;
}

.game-board__footer {
  margin-top: 1rem;
}

.game-board__actions {
  display: flex;
  gap: 0.75rem;
  flex-wrap: wrap;
}

.panel__button--ghost {
  background: rgba(255, 251, 243, 0.72);
  color: var(--vermillion);
  box-shadow: none;
}

.panel__button--ghost:hover {
  background: rgba(255, 247, 234, 0.92);
}

.game-reward {
  flex: 1 1 18rem;
}

.game-reward__card {
  padding: 0.95rem 1rem;
  border-radius: 1.15rem;
}

.game-reward__title {
  font-size: 1.4rem;
}

.game-certificate {
  position: relative;
  z-index: 1;
  margin-top: 1rem;
}

.game-certificate__card {
  appearance: none;
  width: 100%;
  position: relative;
  overflow: hidden;
  padding: 1.5rem 1.55rem 1.35rem;
  border-radius: 1.35rem;
  border: 1px solid rgba(171, 120, 47, 0.22);
  background:
    radial-gradient(circle at 82% 14%, rgba(240, 208, 135, 0.2), transparent 18%),
    linear-gradient(180deg, rgba(255, 252, 246, 0.96), rgba(244, 233, 208, 0.92));
  box-shadow: 0 1.2rem 2.4rem rgba(60, 40, 22, 0.09);
  text-align: left;
  cursor: pointer;
  transition: transform 0.24s ease, border-color 0.24s ease, box-shadow 0.24s ease;
}

.game-certificate__card:hover,
.game-certificate__card:focus-visible {
  transform: translateY(-3px);
  border-color: rgba(171, 120, 47, 0.34);
  box-shadow: 0 1.45rem 2.8rem rgba(60, 40, 22, 0.12);
  outline: none;
}

.game-certificate__card::before {
  content: "";
  position: absolute;
  inset: 0.8rem;
  border-radius: 1rem;
  border: 1px solid rgba(171, 120, 47, 0.14);
  pointer-events: none;
}

.game-certificate__seal {
  position: absolute;
  right: 1.2rem;
  top: 1rem;
  width: 4.5rem;
  aspect-ratio: 1;
  display: grid;
  place-items: center;
  border-radius: 1rem;
  border: 1px solid rgba(157, 47, 32, 0.24);
  background: rgba(157, 47, 32, 0.08);
  color: var(--vermillion);
  font-family: var(--font-display);
  font-size: 1.72rem;
  transform: rotate(-8deg);
}

.game-certificate__label,
.game-certificate__subtitle,
.game-certificate__text,
.game-certificate__grant,
.game-certificate__date {
  margin: 0;
  color: var(--ink-soft);
  font-size: 1rem;
}

.game-certificate__title {
  margin: 0.35rem 0 0;
  font-family: var(--font-display);
  font-size: clamp(1.8rem, 3vw, 2.3rem);
}

.game-certificate__subtitle {
  margin-top: 0.38rem;
  letter-spacing: 0.16rem;
}

.game-certificate__text {
  margin-top: 0.95rem;
  max-width: 44rem;
  line-height: 1.95;
  font-size: 1.06rem;
}

.game-certificate__foot {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
  margin-top: 1rem;
  padding-top: 0.75rem;
  border-top: 1px solid rgba(171, 120, 47, 0.12);
}

.game-certificate__hint {
  display: inline-flex;
  margin-top: 1.05rem;
  padding: 0.48rem 0.82rem;
  border-radius: 999px;
  border: 1px solid rgba(171, 120, 47, 0.16);
  color: rgba(57, 40, 23, 0.7);
  letter-spacing: 0.14rem;
  background: rgba(255, 250, 238, 0.66);
  font-size: 0.96rem;
}

.game-board[data-mode="pending"] .game-yinyang {
  grid-template-columns: 1fr;
}

.game-board[data-mode="pending"] .game-yinyang__zone,
.game-board[data-mode="pending"] .game-yinyang__actions {
  display: none;
}

.game-board[data-mode="pending"] .game-card {
  cursor: default;
}

.game-form,
.game-scene {
  display: grid;
  gap: 1rem;
}

.game-form__target,
.game-scene__card,
.game-map {
  position: relative;
  overflow: hidden;
  border-radius: 1.35rem;
  border: 1px solid rgba(126, 90, 55, 0.14);
  background:
    radial-gradient(circle at 84% 16%, rgba(240, 208, 135, 0.12), transparent 18%),
    linear-gradient(180deg, rgba(255, 251, 243, 0.96), rgba(246, 238, 222, 0.9));
  box-shadow: 0 1rem 2.2rem rgba(60, 40, 22, 0.08);
}

.game-form__target {
  padding: 1rem 1.05rem;
}

.game-form__label,
.game-scene__label,
.game-map__label {
  margin: 0;
  color: var(--ink-soft);
  letter-spacing: 0.18rem;
}

.game-form__title,
.game-scene__title,
.game-map__title {
  margin: 0.35rem 0 0;
  font-family: var(--font-display);
  font-size: clamp(1.55rem, 2.7vw, 2rem);
}

.game-form__note,
.game-scene__note,
.game-map__note {
  margin: 0.45rem 0 0;
  line-height: 1.85;
  color: rgba(41, 31, 22, 0.78);
}

.game-form__builder {
  display: grid;
  grid-template-columns: minmax(14rem, 15.5rem) minmax(0, 1fr);
  gap: 1rem;
  align-items: start;
}

.game-form__plaque {
  grid-row: 1 / span 3;
  display: grid;
  gap: 0.45rem;
  align-content: start;
  justify-items: start;
  padding: 1.15rem 1rem;
  min-height: 100%;
  border-radius: 1.25rem;
  border: 1px solid rgba(126, 90, 55, 0.14);
  background:
    linear-gradient(180deg, rgba(255, 253, 247, 0.92), rgba(245, 235, 214, 0.9));
}

.game-form__glyph {
  font-size: 3rem;
  line-height: 1;
  color: rgba(141, 87, 18, 0.78);
}

.game-form__name {
  font-family: var(--font-display);
  font-size: 1.75rem;
}

.game-form__intro {
  color: rgba(41, 31, 22, 0.78);
  line-height: 1.8;
}

.game-form__slots {
  display: flex;
  flex-direction: column;
  gap: 0.8rem;
  padding: 1rem;
  border-radius: 1.25rem;
  border: 1px solid rgba(126, 90, 55, 0.12);
  background: rgba(255, 252, 245, 0.74);
}

.game-line-slot,
.game-line-piece {
  appearance: none;
  border: 1px solid rgba(126, 90, 55, 0.14);
}

.game-line-slot {
  min-height: 4.1rem;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.7rem;
  padding: 0.75rem 1rem;
  border-radius: 1rem;
  background: linear-gradient(180deg, rgba(255, 250, 242, 0.92), rgba(246, 237, 219, 0.82));
  transition: transform 0.24s ease, border-color 0.24s ease, box-shadow 0.24s ease;
}

.game-line-slot:hover {
  transform: translateY(-2px);
  border-color: rgba(202, 159, 72, 0.42);
}

.game-line-slot.has-line {
  background: linear-gradient(180deg, rgba(255, 247, 231, 0.94), rgba(244, 229, 196, 0.86));
}

.game-line-slot__stroke,
.game-line-piece__stroke {
  flex: 1 1 auto;
  height: 0.82rem;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(188, 140, 51, 0.96), rgba(242, 214, 147, 0.98));
  box-shadow: 0 0.25rem 0.7rem rgba(188, 140, 51, 0.18);
}

.game-line-slot__gap,
.game-line-piece__gap {
  width: 1.2rem;
  height: 0.82rem;
  flex: 0 0 1.2rem;
}

.game-line-slot__placeholder {
  color: rgba(41, 31, 22, 0.46);
  letter-spacing: 0.16rem;
}

.game-form__palette {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.8rem;
}

.game-line-piece {
  display: grid;
  gap: 0.55rem;
  justify-items: center;
  padding: 0.95rem 0.9rem;
  border-radius: 1.05rem;
  background: rgba(255, 251, 243, 0.82);
  transition: transform 0.24s ease, border-color 0.24s ease, box-shadow 0.24s ease;
  cursor: grab;
}

.game-line-piece:hover {
  transform: translateY(-2px);
}

.game-line-piece.is-active {
  border-color: rgba(202, 159, 72, 0.54);
  background: linear-gradient(180deg, rgba(255, 247, 232, 0.94), rgba(244, 231, 201, 0.88));
  box-shadow: 0 0.9rem 1.6rem rgba(60, 40, 22, 0.1);
}

.game-line-piece__figure {
  width: min(100%, 10rem);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.55rem;
}

.game-line-piece__label {
  color: var(--ink-soft);
  letter-spacing: 0.12rem;
}

.game-form__confirm,
.game-map__confirm {
  justify-self: start;
  min-width: 8rem;
}

.game-form__identify {
  display: grid;
  grid-template-columns: minmax(15rem, 0.82fr) minmax(0, 1.18fr);
  gap: 1rem;
  align-items: stretch;
}

.game-form__figure-card {
  display: grid;
  justify-items: center;
  gap: 0.9rem;
  padding: 1.2rem 1rem;
  border-radius: 1.25rem;
  border: 1px solid rgba(126, 90, 55, 0.14);
  background:
    radial-gradient(circle at 50% 18%, rgba(240, 208, 135, 0.16), transparent 20%),
    linear-gradient(180deg, rgba(255, 253, 247, 0.94), rgba(246, 238, 221, 0.9));
}

.game-form__figure-glyph {
  font-size: 3.2rem;
  color: rgba(141, 87, 18, 0.82);
}

.game-form__figure {
  min-width: min(100%, 12.5rem);
}

.game-form__figure .figure__line {
  min-height: 0.92rem;
}

.game-form__choices,
.game-scene__choices {
  display: grid;
  gap: 0.8rem;
}

.game-form__choices {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.game-choice,
.game-scene-choice {
  appearance: none;
  border: 1px solid rgba(126, 90, 55, 0.14);
  border-radius: 1rem;
  background: rgba(255, 251, 243, 0.82);
  transition: transform 0.24s ease, border-color 0.24s ease, box-shadow 0.24s ease;
}

.game-choice:hover,
.game-scene-choice:hover,
.game-bagua-token:hover,
.game-map-slot:hover {
  transform: translateY(-2px);
  border-color: rgba(202, 159, 72, 0.42);
  box-shadow: 0 0.9rem 1.6rem rgba(60, 40, 22, 0.08);
}

.game-choice {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.9rem;
  padding: 0.95rem 1rem;
}

.game-choice--name-only {
  justify-content: center;
  min-height: 5.4rem;
}

.game-choice--figure {
  display: grid;
  justify-items: center;
  gap: 0.7rem;
  min-height: 9.8rem;
}

.game-choice__glyph {
  font-size: 1.7rem;
  color: rgba(141, 87, 18, 0.82);
}

.game-choice__name {
  font-family: var(--font-display);
  font-size: 1.15rem;
  text-align: center;
}

.game-choice__figure {
  min-width: min(100%, 8rem);
}

.game-choice__figure .figure__line {
  min-height: 0.82rem;
}

.game-choice__hint {
  color: var(--ink-soft);
  letter-spacing: 0.12rem;
}

.game-scene__card {
  min-height: 22rem;
  padding: 1.2rem 1.15rem;
  display: grid;
  align-content: end;
}

.game-scene__card.is-scene {
  background:
    radial-gradient(circle at 18% 16%, rgba(248, 238, 206, 0.34), transparent 18%),
    linear-gradient(180deg, rgba(76, 88, 106, 0.96), rgba(213, 185, 134, 0.92));
  color: #fff7ee;
}

.game-scene__card.is-phrase {
  background:
    radial-gradient(circle at 82% 18%, rgba(240, 208, 135, 0.24), transparent 18%),
    linear-gradient(180deg, rgba(113, 79, 52, 0.96), rgba(214, 177, 122, 0.9));
  color: #fff7ef;
}

.game-scene__card.is-object {
  background:
    radial-gradient(circle at 22% 18%, rgba(255, 250, 232, 0.2), transparent 18%),
    linear-gradient(180deg, rgba(74, 100, 90, 0.96), rgba(208, 176, 132, 0.9));
  color: #fff8f1;
}

.game-scene__card.is-scene .game-scene__label,
.game-scene__card.is-scene .game-scene__note,
.game-scene__card.is-phrase .game-scene__label,
.game-scene__card.is-phrase .game-scene__note,
.game-scene__card.is-object .game-scene__label,
.game-scene__card.is-object .game-scene__note {
  color: rgba(255, 246, 234, 0.86);
}

.game-scene__card::before,
.game-scene__card::after {
  content: "";
  position: absolute;
  inset: auto;
  pointer-events: none;
}

.game-scene__card::before {
  left: -6%;
  right: -6%;
  bottom: 0;
  height: 58%;
  opacity: 0.94;
}

.game-scene__card::after {
  right: 7%;
  top: 10%;
  width: 6.5rem;
  height: 6.5rem;
  border-radius: 50%;
  opacity: 0.58;
}

.game-scene__card.is-sky {
  background: linear-gradient(180deg, rgba(60, 81, 119, 0.95), rgba(198, 171, 121, 0.88));
  color: #fff6eb;
}

.game-scene__card.is-sky::before {
  background:
    radial-gradient(circle at 50% 100%, rgba(255, 242, 214, 0.56), transparent 46%),
    linear-gradient(180deg, transparent, rgba(235, 205, 147, 0.28));
}

.game-scene__card.is-sky::after {
  background: radial-gradient(circle, rgba(255, 243, 214, 0.92), transparent 72%);
}

.game-scene__card.is-earth {
  background: linear-gradient(180deg, rgba(170, 143, 104, 0.94), rgba(120, 92, 58, 0.96));
  color: #fff2df;
}

.game-scene__card.is-earth::before {
  background:
    linear-gradient(180deg, transparent, rgba(62, 44, 23, 0.26)),
    radial-gradient(circle at 50% 100%, rgba(235, 214, 170, 0.34), transparent 48%);
}

.game-scene__card.is-earth::after {
  background: radial-gradient(circle, rgba(255, 234, 189, 0.56), transparent 72%);
}

.game-scene__card.is-thunder {
  background: linear-gradient(180deg, rgba(49, 52, 74, 0.96), rgba(122, 81, 56, 0.9));
  color: #fff3ea;
}

.game-scene__card.is-thunder::before {
  background:
    linear-gradient(135deg, transparent 45%, rgba(255, 235, 177, 0.8) 46%, transparent 54%),
    radial-gradient(circle at 50% 100%, rgba(250, 218, 145, 0.3), transparent 44%);
}

.game-scene__card.is-thunder::after {
  background: radial-gradient(circle, rgba(255, 243, 214, 0.72), transparent 70%);
}

.game-scene__card.is-wind {
  background: linear-gradient(180deg, rgba(101, 120, 90, 0.94), rgba(191, 162, 118, 0.9));
  color: #fff8ef;
}

.game-scene__card.is-wind::before {
  background:
    radial-gradient(circle at 20% 100%, rgba(223, 205, 156, 0.34), transparent 42%),
    linear-gradient(180deg, transparent, rgba(51, 74, 52, 0.18));
}

.game-scene__card.is-wind::after {
  background: radial-gradient(circle, rgba(255, 245, 216, 0.58), transparent 72%);
}

.game-scene__card.is-water {
  background: linear-gradient(180deg, rgba(37, 58, 77, 0.96), rgba(79, 116, 138, 0.92));
  color: #f4fbff;
}

.game-scene__card.is-water::before {
  background:
    radial-gradient(circle at 50% 100%, rgba(173, 213, 232, 0.34), transparent 44%),
    linear-gradient(180deg, transparent, rgba(9, 26, 37, 0.18));
}

.game-scene__card.is-water::after {
  background: radial-gradient(circle, rgba(214, 239, 250, 0.42), transparent 72%);
}

.game-scene__card.is-fire {
  background: linear-gradient(180deg, rgba(140, 54, 31, 0.96), rgba(228, 145, 72, 0.92));
  color: #fff7ef;
}

.game-scene__card.is-fire::before {
  background:
    radial-gradient(circle at 50% 100%, rgba(255, 227, 181, 0.46), transparent 44%),
    linear-gradient(180deg, transparent, rgba(124, 42, 28, 0.22));
}

.game-scene__card.is-fire::after {
  background: radial-gradient(circle, rgba(255, 240, 213, 0.62), transparent 72%);
}

.game-scene__card.is-mountain {
  background: linear-gradient(180deg, rgba(88, 80, 96, 0.96), rgba(207, 188, 146, 0.9));
  color: #fff7ef;
}

.game-scene__card.is-mountain::before {
  background:
    linear-gradient(140deg, transparent 20%, rgba(223, 205, 167, 0.42) 20% 45%, transparent 46%),
    linear-gradient(220deg, transparent 18%, rgba(187, 168, 129, 0.34) 18% 44%, transparent 45%);
}

.game-scene__card.is-mountain::after {
  background: radial-gradient(circle, rgba(255, 238, 206, 0.52), transparent 72%);
}

.game-scene__card.is-lake {
  background: linear-gradient(180deg, rgba(108, 125, 158, 0.94), rgba(233, 170, 123, 0.9));
  color: #fff8f2;
}

.game-scene__card.is-lake::before {
  background:
    radial-gradient(circle at 50% 100%, rgba(255, 225, 180, 0.34), transparent 44%),
    linear-gradient(180deg, transparent, rgba(123, 76, 54, 0.16));
}

.game-scene__card.is-lake::after {
  background: radial-gradient(circle, rgba(255, 242, 216, 0.56), transparent 72%);
}

.game-scene__card .game-scene__label,
.game-scene__card .game-scene__note {
  color: rgba(255, 248, 238, 0.88);
}

.game-scene__choices {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  margin-top: 1rem;
}

.game-scene-choice {
  display: grid;
  gap: 0.2rem;
  padding: 0.85rem 0.9rem;
  justify-items: start;
  background: rgba(255, 252, 246, 0.9);
}

.game-scene-choice__glyph {
  font-size: 1.35rem;
  color: rgba(141, 87, 18, 0.78);
}

.game-scene-choice__name {
  font-family: var(--font-display);
  font-size: 1.08rem;
}

.game-scene-choice__scene {
  color: var(--ink-soft);
  font-size: 0.86rem;
}

.game-map {
  display: grid;
  gap: 1rem;
  padding: 1.15rem;
}

.game-map__head {
  display: grid;
  gap: 0.1rem;
}

.game-map__palette {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}

.game-bagua-token {
  appearance: none;
  min-width: 5.8rem;
  display: grid;
  justify-items: center;
  gap: 0.28rem;
  padding: 0.75rem 0.8rem;
  border-radius: 1rem;
  border: 1px solid rgba(126, 90, 55, 0.14);
  background: rgba(255, 251, 243, 0.82);
  transition: transform 0.24s ease, border-color 0.24s ease, box-shadow 0.24s ease;
  cursor: grab;
}

.game-bagua-token.is-active {
  border-color: rgba(202, 159, 72, 0.54);
  background: linear-gradient(180deg, rgba(255, 247, 232, 0.94), rgba(244, 231, 201, 0.88));
  box-shadow: 0 0.9rem 1.6rem rgba(60, 40, 22, 0.1);
}

.game-bagua-token__glyph {
  font-size: 1.55rem;
  color: rgba(141, 87, 18, 0.8);
}

.game-bagua-token__name {
  font-family: var(--font-display);
}

.game-bagua-token.is-glyph-only {
  min-width: 4.4rem;
  padding-inline: 0.7rem;
}

.game-bagua-token.is-glyph-only .game-bagua-token__glyph {
  font-size: 1.9rem;
}

.game-bagua-token.is-name-only {
  min-width: 4.8rem;
  gap: 0;
}

.game-map__grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.85rem;
}

.game-compose,
.game-hexagram-name,
.game-reflect,
.game-rise {
  display: grid;
  gap: 1rem;
  padding: 1.15rem;
}

.game-compose__head,
.game-reflect__head,
.game-rise__head,
.game-hexagram-name__card,
.game-reflect__question {
  border-radius: 1.3rem;
  border: 1px solid rgba(126, 90, 55, 0.12);
  background:
    radial-gradient(circle at 84% 16%, rgba(240, 208, 135, 0.12), transparent 18%),
    linear-gradient(180deg, rgba(255, 252, 246, 0.94), rgba(245, 236, 216, 0.9));
  padding: 1rem 1.05rem;
}

.game-compose__label,
.game-hexagram-name__label,
.game-reflect__label,
.game-rise__label,
.game-reflect__question-label,
.game-compose__preview-label,
.game-compose__slot-label,
.game-rise__selector-label {
  margin: 0;
  color: var(--ink-soft);
  letter-spacing: 0.16rem;
}

.game-compose__title,
.game-hexagram-name__title,
.game-reflect__title,
.game-rise__title,
.game-reflect__question-title,
.game-compose__preview-name {
  margin: 0.2rem 0 0;
  font-family: var(--font-display);
}

.game-compose__note,
.game-hexagram-name__note,
.game-reflect__note,
.game-rise__note,
.game-compose__preview-note,
.game-rise__progress,
.game-compose__slot-placeholder {
  margin: 0.35rem 0 0;
  color: rgba(41, 31, 22, 0.72);
  line-height: 1.8;
}

.game-compose__stage {
  display: grid;
  gap: 1rem;
}

.game-compose__palette,
.game-rise__tokens {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}

.game-compose__palette .game-bagua-token,
.game-rise__tokens .game-bagua-token {
  flex: 1 1 10.5rem;
}

.game-compose__slots {
  display: grid;
  grid-template-columns: minmax(170px, 0.82fr) minmax(0, 1fr) minmax(170px, 0.82fr);
  gap: 0.9rem;
  align-items: stretch;
}

.game-compose__slot,
.game-compose__preview,
.game-reflect__card,
.game-reflect__mirror,
.game-rise__selector,
.game-rise__stairs {
  border-radius: 1.2rem;
  border: 1px solid rgba(126, 90, 55, 0.12);
  background: rgba(255, 251, 243, 0.84);
}

.game-compose__slot {
  appearance: none;
  padding: 0.9rem;
  display: grid;
  gap: 0.65rem;
  align-content: start;
  min-height: 15rem;
}

.game-compose__slot-body {
  display: grid;
  justify-items: center;
  gap: 0.75rem;
}

.game-compose__slot.is-filled {
  box-shadow: 0 1rem 1.8rem rgba(60, 40, 22, 0.08);
}

.game-compose__slot-name {
  margin: 0;
  font-family: var(--font-display);
  font-size: 1.3rem;
}

.game-compose__preview {
  min-height: 15rem;
  display: grid;
  place-items: center;
  justify-items: center;
  text-align: center;
  padding: 1rem;
}

.game-compose__preview-figure .figure,
.game-hexagram-name__figure.figure,
.game-reflect__figure.figure {
  min-width: 10rem;
}

.game-compose__confirm,
.game-reflect__button,
.game-rise__confirm {
  justify-self: start;
}

.game-hexagram-name {
  grid-template-columns: minmax(240px, 0.85fr) minmax(0, 1fr);
  align-items: start;
}

.game-hexagram-name__card {
  display: grid;
  gap: 0.35rem;
  justify-items: center;
  text-align: center;
  min-height: 20rem;
}

.game-hexagram-name__full {
  margin: 0;
  font-family: var(--font-display);
  font-size: 1.4rem;
}

.game-hexagram-name__choices,
.game-reflect__choices {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.85rem;
  align-self: stretch;
}

.game-choice--hexagram-name {
  min-height: 5.8rem;
  display: grid;
  justify-items: center;
  align-content: center;
}

.game-choice__figure--hexagram.figure {
  min-width: 8.8rem;
}

.game-reflect__board {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(190px, 0.72fr) minmax(0, 1fr);
  gap: 0.9rem;
  align-items: stretch;
}

.game-reflect__card,
.game-reflect__mirror {
  padding: 1rem;
  display: grid;
  justify-items: center;
  text-align: center;
  gap: 0.6rem;
  min-height: 17rem;
}

.game-reflect__card.is-revealed {
  box-shadow: 0 1rem 1.8rem rgba(60, 40, 22, 0.08);
}

.game-reflect__card-title {
  margin: 0;
  font-family: var(--font-display);
  font-size: 1.35rem;
}

.game-reflect__card-label {
  margin: 0;
  color: var(--ink-soft);
  letter-spacing: 0.16rem;
}

.game-reflect__seal {
  width: 4.6rem;
  aspect-ratio: 1;
  display: grid;
  place-items: center;
  border-radius: 50%;
  border: 1px solid rgba(157, 47, 32, 0.2);
  background: rgba(157, 47, 32, 0.08);
  color: var(--vermillion);
  font-family: var(--font-display);
  font-size: 1.8rem;
}

.game-reflect__placeholder {
  margin: auto 0;
  color: var(--ink-soft);
  letter-spacing: 0.12rem;
}

.game-rise__body {
  display: grid;
  grid-template-columns: minmax(260px, 0.84fr) minmax(0, 1fr);
  gap: 1rem;
}

.game-rise__stairs {
  padding: 1rem;
  display: grid;
  gap: 0.7rem;
  background:
    radial-gradient(circle at 50% 16%, rgba(240, 208, 135, 0.12), transparent 20%),
    linear-gradient(180deg, rgba(247, 239, 221, 0.9), rgba(238, 227, 201, 0.82));
}

.game-rise__step {
  appearance: none;
  min-height: 3rem;
  border-radius: 1rem;
  border: 1px solid rgba(126, 90, 55, 0.12);
  background: rgba(255, 251, 243, 0.88);
  display: grid;
  place-items: center;
  transition: transform 0.24s ease, border-color 0.24s ease, box-shadow 0.24s ease;
}

.game-rise__step:hover {
  transform: translateY(-2px);
  border-color: rgba(202, 159, 72, 0.42);
  box-shadow: 0 0.9rem 1.6rem rgba(60, 40, 22, 0.08);
}

.game-rise__step.is-lit {
  background:
    radial-gradient(circle at 50% 18%, rgba(255, 248, 230, 0.34), transparent 24%),
    linear-gradient(180deg, rgba(255, 248, 233, 0.94), rgba(244, 230, 194, 0.9));
}

.game-rise__single.figure {
  min-width: 8rem;
}

.game-rise__placeholder {
  color: var(--ink-soft);
  letter-spacing: 0.16rem;
}

.game-rise__side {
  display: grid;
  gap: 0.9rem;
  align-content: start;
}

.game-rise__selectors {
  display: grid;
  gap: 0.9rem;
}

.game-rise__selector {
  padding: 0.95rem 1rem;
  display: grid;
  gap: 0.7rem;
}

.game-rise__confirm {
  min-width: 8rem;
}

.game-questionlab {
  display: grid;
  gap: 1rem;
  padding: 0.3rem 0;
}

.game-questionlab__head,
.game-questionlab__panel,
.game-questionlab__poster-card {
  border-radius: 1.4rem;
  border: 1px solid rgba(126, 90, 55, 0.12);
  background:
    linear-gradient(180deg, rgba(255, 252, 244, 0.94), rgba(248, 239, 220, 0.9));
  box-shadow: 0 16px 36px rgba(143, 103, 58, 0.08);
}

.game-questionlab__head,
.game-questionlab__panel {
  padding: 1rem 1.1rem;
}

.game-questionlab__label,
.game-questionlab__panel-label,
.game-questionlab__poster-title {
  margin: 0;
  font-size: 0.8rem;
  letter-spacing: 0.16rem;
  color: var(--ink-soft);
}

.game-questionlab__title,
.game-questionlab__preview-title {
  margin: 0.5rem 0 0;
  font-family: var(--font-display);
  font-size: clamp(1.4rem, 2vw, 2rem);
  line-height: 1.15;
}

.game-questionlab__note,
.game-questionlab__scene,
.game-questionlab__raw,
.game-questionlab__preview-note,
.game-questionlab__preview-gate,
.game-questionlab__poster-status,
.game-questionlab__card-text,
.game-questionlab__time-question {
  margin: 0.55rem 0 0;
  color: var(--ink-soft);
  line-height: 1.8;
}

.game-questionlab__scene {
  color: var(--ink-strong);
}

.game-questionlab__raw {
  font-size: 1.05rem;
  color: var(--ink);
}

.game-questionlab__layout,
.game-questionlab__stack {
  display: grid;
  gap: 1rem;
}

.game-questionlab__layout--split {
  grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.2fr) minmax(18rem, 0.8fr);
  align-items: start;
}

.game-questionlab__layout--time {
  grid-template-columns: minmax(0, 1.1fr) minmax(18rem, 0.9fr);
  align-items: start;
}

.game-questionlab__layout--poster {
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.95fr);
  align-items: start;
}

.game-questionlab__bins,
.game-questionlab__gates,
.game-questionlab__times,
.game-questionlab__segments,
.game-questionlab__cards,
.game-questionlab__actions {
  display: grid;
  gap: 0.8rem;
}

.game-questionlab__bins,
.game-questionlab__gates {
  grid-template-columns: repeat(auto-fit, minmax(8.5rem, 1fr));
}

.game-questionlab__times {
  grid-template-columns: repeat(auto-fit, minmax(11rem, 1fr));
}

.game-questionlab__segments,
.game-questionlab__cards {
  grid-template-columns: repeat(auto-fit, minmax(15rem, 1fr));
}

.game-questionlab__bin,
.game-questionlab__gate,
.game-questionlab__segment,
.game-questionlab__card-main,
.game-questionlab__primary,
.game-questionlab__time {
  appearance: none;
  width: 100%;
  border: 1px solid rgba(126, 90, 55, 0.12);
  background: rgba(255, 251, 243, 0.86);
  border-radius: 1.15rem;
  color: var(--ink);
  transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease, background 180ms ease;
}

.game-questionlab__bin:hover,
.game-questionlab__gate:hover,
.game-questionlab__segment:hover,
.game-questionlab__card-main:hover,
.game-questionlab__primary:hover,
.game-questionlab__time:hover {
  transform: translateY(-2px);
  border-color: rgba(157, 50, 27, 0.28);
  box-shadow: 0 14px 26px rgba(141, 93, 40, 0.12);
}

.game-questionlab__bin.is-active,
.game-questionlab__gate.is-active,
.game-questionlab__time.is-active,
.game-questionlab__card-main.is-active {
  border-color: rgba(157, 50, 27, 0.34);
  background:
    radial-gradient(circle at top, rgba(204, 167, 76, 0.16), transparent 55%),
    linear-gradient(180deg, rgba(255, 248, 237, 0.98), rgba(248, 236, 205, 0.94));
  box-shadow: 0 18px 30px rgba(141, 93, 40, 0.14);
}

.game-questionlab__bin {
  padding: 0.9rem 1rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 0.8rem;
}

.game-questionlab__bin-label,
.game-questionlab__gate-name,
.game-questionlab__time-label {
  font-weight: 600;
  color: var(--ink-strong);
}

.game-questionlab__bin-count,
.game-questionlab__card-tag,
.game-questionlab__segment-tag {
  min-width: 2.3rem;
  padding: 0.22rem 0.5rem;
  border-radius: 999px;
  background: rgba(204, 167, 76, 0.16);
  font-size: 0.75rem;
  letter-spacing: 0.06rem;
  color: var(--ink-soft);
}

.game-questionlab__segment {
  min-height: 7.6rem;
  padding: 1rem;
  display: grid;
  align-content: space-between;
  text-align: left;
}

.game-questionlab__segment.is-assigned,
.game-questionlab__card.is-assigned {
  border-color: rgba(204, 167, 76, 0.24);
  background:
    radial-gradient(circle at top, rgba(204, 167, 76, 0.14), transparent 60%),
    rgba(255, 251, 243, 0.9);
}

.game-questionlab__segment-text {
  line-height: 1.85;
}

.game-questionlab__gate {
  padding: 0.85rem 0.95rem;
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.game-questionlab__gate-seal {
  width: 2.4rem;
  height: 2.4rem;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: rgba(204, 167, 76, 0.16);
  color: var(--accent);
  font-family: var(--font-display);
  font-size: 1rem;
}

.game-questionlab__card {
  padding: 0.85rem;
  display: grid;
  gap: 0.65rem;
  border-radius: 1.2rem;
  border: 1px solid rgba(126, 90, 55, 0.12);
  background: rgba(255, 251, 243, 0.88);
  cursor: pointer;
  transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease, background 180ms ease;
}

.game-questionlab__card:hover {
  transform: translateY(-2px);
  border-color: rgba(157, 50, 27, 0.26);
  box-shadow: 0 14px 26px rgba(141, 93, 40, 0.12);
}

.game-questionlab__card.is-primary {
  box-shadow: 0 18px 30px rgba(157, 50, 27, 0.12);
  border-color: rgba(157, 50, 27, 0.26);
}

.game-questionlab__card-main {
  min-height: 8.6rem;
  padding: 1rem;
  display: grid;
  align-content: space-between;
  text-align: left;
}

.game-questionlab__primary {
  padding: 0.72rem 0.9rem;
  font-size: 0.9rem;
}

.game-questionlab__preview-gate {
  margin: 0.4rem 0 0;
  color: var(--accent);
  font-weight: 600;
}

.game-questionlab__primary.is-active {
  background: rgba(157, 50, 27, 0.1);
  border-color: rgba(157, 50, 27, 0.24);
}

.game-questionlab__time {
  padding: 0.95rem 1rem;
  display: grid;
  gap: 0.3rem;
  text-align: left;
}

.game-questionlab__time-question {
  font-size: 0.86rem;
}

.game-questionlab__poster {
  display: grid;
  gap: 0.9rem;
}

.game-questionlab__poster-card {
  padding: 1rem 1.1rem;
}

.game-questionlab__poster-card.is-revealed {
  background:
    radial-gradient(circle at top, rgba(204, 167, 76, 0.18), transparent 52%),
    linear-gradient(180deg, rgba(255, 250, 240, 0.98), rgba(247, 234, 201, 0.92));
}

.game-questionlab__poster-grid {
  margin-top: 0.8rem;
  display: grid;
  gap: 0.7rem;
}

.game-questionlab__poster-row {
  display: grid;
  gap: 0.22rem;
  padding-bottom: 0.7rem;
  border-bottom: 1px dashed rgba(126, 90, 55, 0.14);
}

.game-questionlab__poster-row:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

.game-questionlab__poster-row span {
  font-size: 0.78rem;
  letter-spacing: 0.14rem;
  color: var(--ink-soft);
}

.game-questionlab__poster-row strong {
  font-weight: 500;
  line-height: 1.8;
  color: var(--ink-strong);
}

.game-questionlab__actions {
  justify-content: end;
}

.game-questionlab__confirm {
  min-width: 8rem;
}

.game-questionlab--cast .game-questionlab__layout--poster {
  grid-template-columns: minmax(0, 1.15fr) minmax(22rem, 0.95fr);
}

.game-cast__shichen-grid,
.game-cast__token-grid,
.game-cast__chip-grid,
.game-cast__line-grid {
  display: grid;
  gap: 0.8rem;
}

.game-cast__shichen-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.game-cast__shichen {
  appearance: none;
  width: 100%;
  display: grid;
  gap: 0.28rem;
  padding: 0.95rem 0.8rem;
  border-radius: 1.15rem;
  border: 1px solid rgba(126, 90, 55, 0.12);
  background: rgba(255, 251, 243, 0.88);
  color: var(--ink);
  transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease, background 180ms ease;
}

.game-cast__shichen:hover,
.game-cast__line-choice:hover {
  transform: translateY(-2px);
  border-color: rgba(157, 50, 27, 0.28);
  box-shadow: 0 14px 26px rgba(141, 93, 40, 0.12);
}

.game-cast__shichen.is-active,
.game-cast__line-choice.is-active {
  border-color: rgba(157, 50, 27, 0.34);
  background:
    radial-gradient(circle at top, rgba(204, 167, 76, 0.16), transparent 55%),
    linear-gradient(180deg, rgba(255, 248, 237, 0.98), rgba(248, 236, 205, 0.94));
  box-shadow: 0 18px 30px rgba(141, 93, 40, 0.14);
}

.game-cast__shichen-name,
.game-cast__formula-title,
.game-cast__line-choice {
  font-weight: 600;
  color: var(--ink-strong);
}

.game-cast__shichen-range {
  color: var(--ink-soft);
  font-size: 0.82rem;
  letter-spacing: 0.05rem;
}

.game-cast__chip-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.game-cast__chip {
  padding: 0.8rem 0.9rem;
  border-radius: 1rem;
  border: 1px solid rgba(126, 90, 55, 0.12);
  background:
    linear-gradient(180deg, rgba(255, 252, 244, 0.94), rgba(248, 239, 220, 0.9));
  display: grid;
  gap: 0.22rem;
}

.game-cast__chip-label {
  color: var(--ink-soft);
  letter-spacing: 0.12rem;
  font-size: 0.78rem;
}

.game-cast__chip-value {
  font-size: 1.2rem;
  color: var(--ink-strong);
}

.game-cast__formula {
  display: grid;
  gap: 0.8rem;
  padding: 1rem 1.1rem;
  border-radius: 1.4rem;
  border: 1px solid rgba(126, 90, 55, 0.12);
  background:
    linear-gradient(180deg, rgba(255, 252, 244, 0.94), rgba(248, 239, 220, 0.9));
  box-shadow: 0 16px 36px rgba(143, 103, 58, 0.08);
}

.game-cast__formula-title {
  margin: 0;
  font-size: 1.24rem;
}

.game-cast__formula-math {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
  color: var(--ink-soft);
}

.game-cast__formula-math span {
  padding: 0.3rem 0.6rem;
  border-radius: 999px;
  background: rgba(204, 167, 76, 0.14);
}

.game-cast__token-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.game-cast__token-grid .game-bagua-token {
  min-height: 6rem;
  justify-items: center;
  padding: 0.8rem 0.55rem;
}

.game-cast__preview-figure {
  margin-top: 0.2rem;
  display: grid;
  place-items: center;
  padding: 0.9rem;
  border-radius: 1.15rem;
  background: rgba(255, 250, 242, 0.8);
  border: 1px solid rgba(126, 90, 55, 0.1);
}

.game-cast__triple {
  display: grid;
  gap: 0.8rem;
}

.game-cast__triple-card,
.game-cast__poster-figure {
  display: grid;
  gap: 0.75rem;
  justify-items: center;
  padding: 1rem 0.9rem;
  border-radius: 1.15rem;
  border: 1px solid rgba(126, 90, 55, 0.12);
  background: rgba(255, 250, 242, 0.84);
}

.game-cast__triple-card p,
.game-cast__poster-figure p,
.game-cast__poster-label {
  margin: 0;
  letter-spacing: 0.14rem;
  color: var(--ink-soft);
}

.game-cast__line-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.game-cast__line-choice {
  appearance: none;
  width: 100%;
  padding: 0.95rem 0.8rem;
  border-radius: 1.1rem;
  border: 1px solid rgba(126, 90, 55, 0.12);
  background: rgba(255, 251, 243, 0.88);
}

.game-cast__poster-wrap {
  display: grid;
  gap: 0.8rem;
}

.game-cast__poster {
  padding: 1rem 1.1rem;
  border-radius: 1.4rem;
  border: 1px solid rgba(126, 90, 55, 0.12);
  background:
    linear-gradient(180deg, rgba(255, 252, 244, 0.94), rgba(248, 239, 220, 0.9));
  box-shadow: 0 16px 36px rgba(143, 103, 58, 0.08);
  display: grid;
  gap: 0.85rem;
}

.game-cast__poster.is-revealed {
  background:
    radial-gradient(circle at top, rgba(204, 167, 76, 0.18), transparent 52%),
    linear-gradient(180deg, rgba(255, 250, 240, 0.98), rgba(247, 234, 201, 0.92));
}

.game-cast__poster-grid {
  display: grid;
  gap: 0.62rem;
}

.game-cast__poster-row {
  display: grid;
  gap: 0.2rem;
  padding-bottom: 0.62rem;
  border-bottom: 1px dashed rgba(126, 90, 55, 0.14);
}

.game-cast__poster-row:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

.game-cast__poster-row span {
  font-size: 0.78rem;
  letter-spacing: 0.12rem;
  color: var(--ink-soft);
}

.game-cast__poster-row strong {
  font-weight: 600;
  color: var(--ink-strong);
  line-height: 1.75;
}

.game-cast__poster-figures {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.8rem;
}

.game-questionlab__panel--preview {
  display: grid;
  gap: 0.65rem;
  align-content: start;
}

.game-questionlab__guide-list {
  margin-top: 0.8rem;
  display: grid;
  gap: 0.75rem;
}

.game-questionlab__guide-item {
  display: grid;
  grid-template-columns: 2rem 1fr;
  gap: 0.8rem;
  align-items: start;
}

.game-questionlab__guide-item p {
  margin: 0;
  line-height: 1.8;
  color: var(--ink-soft);
}

.game-questionlab__guide-index {
  width: 2rem;
  height: 2rem;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: rgba(204, 167, 76, 0.18);
  color: var(--accent);
  font-family: var(--font-display);
}

.game-mingji__intro,
.game-mingji__ticket-grid,
.game-mingji__slot-grid,
.game-mingji__poster-figures,
.game-mingji__verdict-grid,
.game-mingji__state-grid {
  display: grid;
  gap: 1rem;
}

.game-mingji__intro,
.game-mingji__ticket-grid,
.game-mingji__slot-grid,
.game-mingji__poster-figures,
.game-mingji__state-grid {
  grid-template-columns: repeat(auto-fit, minmax(13rem, 1fr));
}

.game-mingji__ticket {
  display: grid;
  gap: 0.9rem;
}

.game-mingji__ticket-note,
.game-mingji__trigram-meta,
.game-mingji__slot-note,
.game-mingji__gate-note,
.game-mingji__verdict-note {
  margin: 0;
  color: var(--ink-soft);
  line-height: 1.75;
}

.game-mingji__trigram-card,
.game-mingji__slot,
.game-mingji__state-card {
  border-radius: 1.2rem;
  border: 1px solid rgba(126, 90, 55, 0.12);
  background: rgba(255, 250, 242, 0.84);
}

.game-mingji__trigram-card {
  display: grid;
  gap: 0.75rem;
  justify-items: center;
  padding: 1rem 0.9rem;
  text-align: center;
}

.game-mingji__trigram-label,
.game-mingji__slot-title {
  color: var(--ink-soft);
  letter-spacing: 0.14rem;
}

.game-mingji__trigram-name {
  margin: 0.2rem 0 0;
  font-family: var(--font-display);
  font-size: 1.28rem;
  color: var(--ink-strong);
}

.game-mingji__trigram-figure,
.game-mingji__slot-figure {
  display: grid;
  place-items: center;
  padding: 0.85rem;
  border-radius: 1rem;
  background: rgba(255, 255, 255, 0.42);
}

.game-mingji__slot {
  appearance: none;
  width: 100%;
  display: grid;
  gap: 0.8rem;
  padding: 1rem;
  text-align: left;
  transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease, background 180ms ease;
}

.game-mingji__slot:hover {
  transform: translateY(-2px);
  border-color: rgba(157, 50, 27, 0.28);
  box-shadow: 0 14px 26px rgba(141, 93, 40, 0.12);
}

.game-mingji__slot.is-assigned {
  border-color: rgba(157, 50, 27, 0.28);
  background:
    radial-gradient(circle at top, rgba(204, 167, 76, 0.14), transparent 56%),
    linear-gradient(180deg, rgba(255, 248, 237, 0.96), rgba(248, 236, 205, 0.9));
}

.game-mingji__slot-top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 0.8rem;
}

.game-mingji__slot-badge {
  padding: 0.25rem 0.68rem;
  border-radius: 999px;
  background: rgba(204, 167, 76, 0.18);
  color: var(--accent);
  font-family: var(--font-display);
}

.game-mingji__state-card {
  display: grid;
  gap: 0.7rem;
  padding: 1rem;
}

.game-mingji__state-top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 0.8rem;
}

.game-mingji__state-chip {
  padding: 0.24rem 0.65rem;
  border-radius: 999px;
  background: rgba(204, 167, 76, 0.18);
  color: var(--accent);
  letter-spacing: 0.08rem;
}

.game-mingji__gate-note {
  display: block;
  margin-left: auto;
  margin-top: 0.22rem;
  font-size: 0.82rem;
}

.game-mingji__verdict-grid {
  grid-template-columns: repeat(auto-fit, minmax(11rem, 1fr));
}

.game-mingji__verdict {
  appearance: none;
  width: 100%;
  padding: 0.95rem 1rem;
  display: grid;
  gap: 0.3rem;
  text-align: left;
  border-radius: 1.15rem;
  border: 1px solid rgba(126, 90, 55, 0.12);
  background: rgba(255, 251, 243, 0.88);
  color: var(--ink);
  transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease, background 180ms ease;
}

.game-mingji__verdict:hover {
  transform: translateY(-2px);
  border-color: rgba(157, 50, 27, 0.28);
  box-shadow: 0 14px 26px rgba(141, 93, 40, 0.12);
}

.game-mingji__verdict.is-active {
  border-color: rgba(157, 50, 27, 0.34);
  background:
    radial-gradient(circle at top, rgba(204, 167, 76, 0.16), transparent 55%),
    linear-gradient(180deg, rgba(255, 248, 237, 0.98), rgba(248, 236, 205, 0.94));
  box-shadow: 0 18px 30px rgba(141, 93, 40, 0.14);
}

.game-mingji__verdict-title {
  font-weight: 600;
  color: var(--ink-strong);
}

.game-mingji__poster {
  gap: 0.95rem;
}

.game-duanji__intro,
.game-duanji__hexagram-grid,
.game-duanji__poster-figures,
.game-duanji__marker-grid {
  display: grid;
  gap: 1rem;
}

.game-duanji__intro,
.game-duanji__hexagram-grid,
.game-duanji__poster-figures {
  grid-template-columns: repeat(auto-fit, minmax(14rem, 1fr));
}

.game-duanji__context-card,
.game-duanji__hexagram-card,
.game-duanji__choice {
  border-radius: 1.2rem;
  border: 1px solid rgba(126, 90, 55, 0.12);
  background: rgba(255, 251, 243, 0.88);
}

.game-duanji__context-card {
  display: grid;
  gap: 0.85rem;
}

.game-duanji__context-figure,
.game-duanji__hexagram-figure {
  display: grid;
  place-items: center;
  padding: 0.9rem;
  border-radius: 1rem;
  background:
    radial-gradient(circle at top, rgba(204, 167, 76, 0.12), transparent 56%),
    rgba(255, 255, 255, 0.44);
}

.game-duanji__summary-grid {
  display: grid;
  gap: 0.5rem;
}

.game-duanji__summary-row {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  padding-bottom: 0.5rem;
  border-bottom: 1px solid rgba(126, 90, 55, 0.08);
}

.game-duanji__summary-row span,
.game-duanji__card-note {
  color: var(--ink-soft);
}

.game-duanji__summary-row strong {
  color: var(--ink-strong);
  text-align: right;
}

.game-duanji__hexagram-card {
  display: grid;
  gap: 0.8rem;
  padding: 1rem;
}

.game-duanji__card-note {
  margin: 0;
  line-height: 1.75;
}

.game-duanji__marker-grid {
  grid-template-columns: repeat(auto-fit, minmax(11rem, 1fr));
}

.game-duanji__choice {
  appearance: none;
  width: 100%;
  padding: 0.95rem 1rem;
  display: grid;
  gap: 0.45rem;
  text-align: left;
  transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease, background 180ms ease;
}

.game-duanji__choice:hover {
  transform: translateY(-2px);
  border-color: rgba(157, 50, 27, 0.28);
  box-shadow: 0 14px 26px rgba(141, 93, 40, 0.12);
}

.game-duanji__choice.is-active {
  border-color: rgba(157, 50, 27, 0.34);
  background:
    radial-gradient(circle at top, rgba(204, 167, 76, 0.16), transparent 55%),
    linear-gradient(180deg, rgba(255, 248, 237, 0.98), rgba(248, 236, 205, 0.94));
  box-shadow: 0 18px 30px rgba(141, 93, 40, 0.14);
}

.game-duanji__choice-top {
  display: flex;
  align-items: center;
  gap: 0.7rem;
}

.game-duanji__choice-seal {
  min-width: 2rem;
  height: 2rem;
  border-radius: 999px;
  display: grid;
  place-items: center;
  background: rgba(204, 167, 76, 0.18);
  color: var(--accent);
  font-family: var(--font-display);
}

.game-duanji__choice-title {
  font-weight: 600;
  color: var(--ink-strong);
}

.game-duanji__choice-note {
  color: var(--ink-soft);
  line-height: 1.7;
}

.game-duanji__poster {
  gap: 0.95rem;
}

[data-realm="shenji"] .game-ritual__figure {
  background:
    radial-gradient(circle at 50% 50%, rgba(204, 167, 76, 0.16), transparent 55%),
    linear-gradient(180deg, rgba(255, 251, 242, 0.72), rgba(240, 225, 191, 0.18));
}

[data-realm="shenji"] .game-ritual__seal {
  box-shadow:
    0 0 0 1px rgba(157, 50, 27, 0.18),
    0 0 36px rgba(204, 167, 76, 0.28);
}

.game-map-slot {
  appearance: none;
  min-height: 9rem;
  display: grid;
  gap: 0.4rem;
  align-content: space-between;
  padding: 0.95rem 0.9rem;
  border-radius: 1.05rem;
  border: 1px solid rgba(126, 90, 55, 0.14);
  background: rgba(255, 251, 243, 0.84);
  text-align: left;
  transition: transform 0.24s ease, border-color 0.24s ease, box-shadow 0.24s ease;
}

.game-map-slot.is-selected {
  border-color: rgba(202, 159, 72, 0.54);
  box-shadow: 0 0 0 2px rgba(202, 159, 72, 0.18);
}

.game-map-slot.is-sky { background: linear-gradient(180deg, rgba(240, 245, 252, 0.96), rgba(226, 216, 192, 0.9)); }
.game-map-slot.is-earth { background: linear-gradient(180deg, rgba(245, 236, 220, 0.96), rgba(224, 200, 164, 0.9)); }
.game-map-slot.is-thunder { background: linear-gradient(180deg, rgba(238, 236, 246, 0.96), rgba(214, 196, 173, 0.9)); }
.game-map-slot.is-wind { background: linear-gradient(180deg, rgba(241, 246, 236, 0.96), rgba(217, 208, 177, 0.9)); }
.game-map-slot.is-water { background: linear-gradient(180deg, rgba(235, 246, 251, 0.96), rgba(204, 221, 231, 0.9)); }
.game-map-slot.is-fire { background: linear-gradient(180deg, rgba(252, 239, 231, 0.96), rgba(239, 213, 183, 0.9)); }
.game-map-slot.is-mountain { background: linear-gradient(180deg, rgba(244, 241, 235, 0.96), rgba(221, 211, 189, 0.9)); }
.game-map-slot.is-lake { background: linear-gradient(180deg, rgba(244, 242, 251, 0.96), rgba(235, 216, 190, 0.9)); }

.game-map-slot__label {
  color: var(--ink-soft);
  letter-spacing: 0.14rem;
}

.game-map-slot__desc {
  color: rgba(41, 31, 22, 0.72);
  line-height: 1.75;
}

.game-map-slot__assigned {
  justify-self: start;
  padding: 0.25rem 0.62rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.6);
  color: rgba(111, 71, 16, 0.92);
  font-family: var(--font-display);
}

.trigram-showcase {
  isolation: isolate;
}

.trigram-showcase__heading {
  display: flex;
  align-items: center;
  gap: 1rem;
  flex-wrap: wrap;
}

.trigram-showcase__seal {
  width: 3.5rem;
  height: 3.5rem;
  display: grid;
  place-items: center;
  border: 1px solid rgba(157, 47, 32, 0.6);
  color: var(--vermillion);
  font-family: var(--font-display);
  font-size: 1.6rem;
  transform: rotate(-8deg);
  box-shadow: inset 0 0 0 0.28rem rgba(157, 47, 32, 0.06);
}

.trigram-showcase__titles {
  display: grid;
  gap: 0.32rem;
}

.trigram-showcase__label {
  margin: 0;
  color: var(--ink-soft);
  letter-spacing: 0.2rem;
}

.trigram-stage {
  position: relative;
  z-index: 1;
  overflow: hidden;
  border-radius: 1.55rem;
  border: 1px solid rgba(127, 92, 55, 0.14);
  background:
    linear-gradient(135deg, rgba(157, 47, 32, 0.03), transparent 34%),
    linear-gradient(180deg, rgba(253, 250, 243, 0.92), rgba(247, 239, 221, 0.88));
  box-shadow: 0 1rem 2.2rem rgba(60, 40, 22, 0.08);
}

.trigram-stage__halo {
  position: absolute;
  width: 24rem;
  height: 24rem;
  border-radius: 50%;
  filter: blur(24px);
  opacity: 0.4;
  pointer-events: none;
}

.trigram-stage__halo--a {
  left: -6rem;
  top: -7rem;
  background: radial-gradient(circle, rgba(255, 255, 255, 0.4), transparent 72%);
  animation: washFloat 15s ease-in-out infinite;
}

.trigram-stage__halo--b {
  right: -7rem;
  bottom: -7rem;
  background: radial-gradient(circle, rgba(240, 208, 135, 0.3), transparent 72%);
  animation: washFloat 18s ease-in-out infinite reverse;
}

.trigram-stage__panel {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(0, 1.52fr) minmax(280px, 0.68fr);
  gap: 1.15rem;
  align-items: stretch;
  padding: 1.1rem;
}

.trigram-stage__scene {
  min-height: 27rem;
  display: flex;
}

.trigram-stage__copy {
  display: grid;
  gap: 0.85rem;
  align-content: center;
  padding-right: 0.35rem;
}

.trigram-stage__scene > .trigram-visual {
  flex: 1 1 auto;
  width: 100%;
  min-height: 100%;
}

.trigram-stage__label {
  margin: 0;
  color: var(--ink-soft);
  letter-spacing: 0.24rem;
}

.trigram-stage__name {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(2rem, 4vw, 3rem);
  letter-spacing: 0.14rem;
}

.trigram-stage__full {
  margin: 0;
  color: rgba(44, 31, 21, 0.78);
  font-size: 1.04rem;
}

.trigram-stage__recipe {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
}

.trigram-stage__chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.3rem;
  padding: 0.4rem 0.85rem;
  border-radius: 999px;
  border: 1px solid rgba(202, 159, 72, 0.18);
  background: rgba(255, 250, 242, 0.72);
  color: rgba(39, 26, 16, 0.86);
  letter-spacing: 0.14rem;
  opacity: 0;
  transform: translateY(10px);
  animation: fadeSlide 0.55s ease forwards;
  animation-delay: var(--chip-delay, 0ms);
}

.trigram-stage__chip.is-yang {
  box-shadow: inset 0 0 0 1px rgba(240, 208, 135, 0.16);
}

.trigram-stage__chip.is-yin {
  background: rgba(248, 240, 222, 0.92);
}

.trigram-stage__figure {
  padding: 1.1rem 1rem;
  border-radius: 1.2rem;
  background: rgba(255, 250, 242, 0.72);
  border: 1px solid rgba(202, 159, 72, 0.16);
  width: fit-content;
}

.trigram-stage__figure .figure {
  min-width: 11rem;
  gap: 0.8rem;
}

.trigram-stage__figure .figure__line {
  height: 1.15rem;
}

.trigram-stage__dots {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
  margin-top: 0.35rem;
}

.trigram-stage__dot {
  appearance: none;
  width: 0.82rem;
  height: 0.82rem;
  padding: 0;
  border-radius: 50%;
  border: 1px solid rgba(202, 159, 72, 0.28);
  background: rgba(202, 159, 72, 0.16);
  cursor: pointer;
  transition: transform 0.3s ease, background 0.3s ease, box-shadow 0.3s ease;
}

.trigram-stage__dot.is-active {
  background: linear-gradient(135deg, rgba(190, 145, 63, 0.98), rgba(240, 208, 135, 0.96));
  box-shadow: 0 0 0.9rem rgba(240, 208, 135, 0.38);
  transform: scale(1.18);
}

.trigram-grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1rem;
  margin-top: 1rem;
}

.hexagram-flow {
  isolation: isolate;
}

.hexagram-flow__heading {
  display: flex;
  align-items: center;
  gap: 1rem;
  flex-wrap: wrap;
}

.hexagram-flow__seal {
  width: 3.5rem;
  height: 3.5rem;
  display: grid;
  place-items: center;
  border: 1px solid rgba(157, 47, 32, 0.6);
  color: var(--vermillion);
  font-family: var(--font-display);
  font-size: 1.55rem;
  transform: rotate(-8deg);
  box-shadow: inset 0 0 0 0.28rem rgba(157, 47, 32, 0.06);
}

.hexagram-flow__titles {
  display: grid;
  gap: 0.32rem;
}

.hexagram-flow__label {
  margin: 0;
  color: var(--ink-soft);
  letter-spacing: 0.2rem;
}

.hexagram-flow__button {
  min-width: 10rem;
}

.hexagram-flow__button--ghost {
  background: rgba(157, 47, 32, 0.06);
  color: var(--vermillion);
  border: 1px solid rgba(157, 47, 32, 0.12);
  box-shadow: none;
}

.hexagram-flow__panel {
  position: relative;
  z-index: 1;
  overflow: hidden;
  display: grid;
  gap: 1rem;
  border-radius: 1.55rem;
  border: 1px solid rgba(127, 92, 55, 0.14);
  background:
    radial-gradient(circle at 18% 18%, rgba(255, 255, 255, 0.22), transparent 18%),
    linear-gradient(180deg, rgba(253, 250, 243, 0.92), rgba(247, 239, 221, 0.88));
  box-shadow: 0 1rem 2.2rem rgba(60, 40, 22, 0.08);
  padding: 1rem;
}

.hexagram-flow__toolbar {
  display: grid;
  grid-template-columns: minmax(320px, 0.88fr) auto;
  gap: 1rem;
  align-items: stretch;
}

.hexagram-flow__selection {
  display: grid;
  gap: 0.4rem;
  padding: 1.15rem 1.2rem;
  border-radius: 1.3rem;
  border: 1px solid rgba(202, 159, 72, 0.16);
  background:
    radial-gradient(circle at 14% 18%, rgba(255, 255, 255, 0.26), transparent 24%),
    linear-gradient(180deg, rgba(255, 251, 244, 0.82), rgba(247, 238, 220, 0.9));
}

.hexagram-flow__meta,
.hexagram-flow__pair {
  margin: 0;
  color: var(--ink-soft);
  letter-spacing: 0.16rem;
}

.hexagram-flow__current {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(1.6rem, 3vw, 2.25rem);
  letter-spacing: 0.08rem;
}

.hexagram-flow__figure {
  padding-top: 0.45rem;
}

.hexagram-flow__figure .figure {
  min-width: 11rem;
  gap: 0.72rem;
}

.hexagram-flow__figure .figure__line {
  height: 0.95rem;
}

.hexagram-flow__controls {
  display: grid;
  gap: 0.85rem;
  align-content: center;
}

.hexagram-flow__preview {
  display: grid;
  grid-template-columns: repeat(8, minmax(0, 1fr));
  gap: 0.6rem;
}

.screen-evolution__mist {
  position: absolute;
  width: 34rem;
  height: 34rem;
  border-radius: 50%;
  filter: blur(28px);
  pointer-events: none;
}

.screen-evolution__mist--a {
  left: -10rem;
  top: -8rem;
  background: radial-gradient(circle, rgba(255, 221, 157, 0.14), transparent 72%);
  animation: washFloat 18s ease-in-out infinite;
}

.screen-evolution__mist--b {
  right: -10rem;
  bottom: -9rem;
  background: radial-gradient(circle, rgba(255, 248, 234, 0.12), transparent 72%);
  animation: washFloat 22s ease-in-out infinite reverse;
}

.screen-evolution__veil {
  position: absolute;
  top: 50%;
  width: min(38vw, 34rem);
  height: 1px;
  opacity: 0.34;
  filter: blur(0.6px);
  background: linear-gradient(90deg, transparent, rgba(240, 208, 135, 0.72), transparent);
  pointer-events: none;
}

.screen-evolution__veil--a {
  left: -6rem;
  transform: rotate(10deg);
}

.screen-evolution__veil--b {
  right: -6rem;
  transform: rotate(-10deg);
}

.screen-evolution__inner {
  position: relative;
  width: 100vw;
  height: 100vh;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  gap: 1rem;
  padding: clamp(1rem, 2vw, 2rem) clamp(1rem, 2.6vw, 2.6rem);
}

.screen-evolution__topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}

.screen-evolution__titles {
  display: grid;
  gap: 0.35rem;
}

.screen-evolution__label,
.screen-evolution__mode,
.screen-evolution__meta,
.screen-evolution__progress {
  margin: 0;
  color: rgba(240, 224, 190, 0.72);
  letter-spacing: 0.2rem;
}

.screen-evolution__title {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(2rem, 4vw, 3.4rem);
  color: rgba(255, 246, 223, 0.94);
  letter-spacing: 0.12rem;
}

.screen-evolution__actions {
  display: flex;
  gap: 0.8rem;
  flex-wrap: wrap;
}

.screen-evolution__button {
  appearance: none;
  min-height: 3rem;
  padding: 0.75rem 1.35rem;
  border-radius: 999px;
  border: 1px solid rgba(240, 208, 135, 0.28);
  background: linear-gradient(135deg, rgba(190, 145, 63, 0.94), rgba(240, 208, 135, 0.92));
  color: rgba(32, 19, 10, 0.92);
  cursor: pointer;
  letter-spacing: 0.18rem;
  transition: transform 0.3s ease, box-shadow 0.3s ease, background 0.3s ease;
}

.screen-evolution__button:hover {
  transform: translateY(-1px);
  box-shadow: 0 0 1rem rgba(240, 208, 135, 0.26);
}

.screen-evolution__button--ghost {
  background: rgba(255, 250, 241, 0.06);
  color: rgba(255, 243, 214, 0.9);
}

.screen-evolution__body {
  display: grid;
  grid-template-rows: minmax(0, 1fr) auto;
  gap: 1rem;
  min-height: 0;
}

.screen-evolution__arena,
.screen-evolution__matrix {
  min-height: 0;
  border-radius: 1.6rem;
  border: 1px solid rgba(240, 208, 135, 0.12);
  background: rgba(255, 250, 241, 0.04);
  backdrop-filter: blur(10px);
}

.screen-evolution__arena {
  position: relative;
  display: grid;
  grid-template-columns: minmax(15rem, 1fr) minmax(18rem, 0.82fr) minmax(15rem, 1fr);
  gap: clamp(1rem, 4vw, 4.2rem);
  align-items: center;
  padding: clamp(1.2rem, 4vw, 3rem);
  overflow: hidden;
  isolation: isolate;
}

.screen-evolution__arena::before,
.screen-evolution__arena::after {
  content: "";
  position: absolute;
  inset: 50%;
  translate: -50% -50%;
  border-radius: 50%;
  pointer-events: none;
}

.screen-evolution__arena::before {
  width: min(58vw, 40rem);
  height: min(58vw, 40rem);
  border: 1px solid rgba(240, 208, 135, 0.12);
}

.screen-evolution__arena::after {
  width: min(44vw, 30rem);
  height: min(44vw, 30rem);
  border: 1px dashed rgba(240, 208, 135, 0.18);
  animation: spinSlow 32s linear infinite;
}

.screen-evolution__stream,
.screen-evolution__burst,
.screen-evolution__wing,
.screen-evolution__fusion,
.screen-evolution__seal,
.screen-evolution__hexagram-figure,
.screen-evolution__hexagram-name {
  opacity: 0;
}

.screen-evolution__stream {
  position: relative;
  height: 2px;
  background: linear-gradient(90deg, transparent, rgba(240, 208, 135, 0.88), transparent);
  filter: drop-shadow(0 0 0.6rem rgba(240, 208, 135, 0.24));
}

.screen-evolution__stream--left,
.screen-evolution__stream--right {
  position: absolute;
  top: 50%;
  width: 34%;
}

.screen-evolution__stream--left {
  left: 4%;
}

.screen-evolution__stream--right {
  right: 4%;
}

.screen-evolution__burst {
  position: absolute;
  left: 50%;
  top: 50%;
  width: min(24vw, 14rem);
  height: min(24vw, 14rem);
  translate: -50% -50%;
  border-radius: 50%;
  background:
    radial-gradient(circle, rgba(240, 208, 135, 0.42), rgba(240, 208, 135, 0.06) 56%, transparent 72%),
    repeating-conic-gradient(from 0deg, rgba(240, 208, 135, 0.24) 0deg 10deg, transparent 10deg 28deg);
  filter: blur(0.3px);
}

.screen-evolution__wing,
.screen-evolution__fusion {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 0.85rem;
  justify-items: center;
  text-align: center;
  padding: 1.2rem;
  border-radius: 1.7rem;
  border: 1px solid rgba(240, 208, 135, 0.14);
  background:
    radial-gradient(circle at 50% 0%, rgba(255, 247, 224, 0.08), transparent 38%),
    rgba(255, 250, 241, 0.04);
  box-shadow: inset 0 0 0 1px rgba(255, 247, 224, 0.03);
  backdrop-filter: blur(10px);
}

.screen-evolution__wing {
  min-height: 24rem;
  align-content: center;
}

.screen-evolution__fusion {
  min-height: 29rem;
  align-content: center;
}

.screen-evolution__visual,
.screen-evolution__hexagram-figure {
  width: 100%;
  border-radius: 1.3rem;
  border: 1px solid rgba(240, 208, 135, 0.14);
  background: rgba(255, 250, 241, 0.04);
}

.screen-evolution__visual {
  min-height: 16rem;
  overflow: hidden;
}

.trigram-visual--evolution {
  min-height: 16rem;
  border-radius: 1.35rem;
}

.screen-evolution__name,
.screen-evolution__hexagram-name {
  margin: 0;
  font-family: var(--font-display);
  color: rgba(255, 246, 223, 0.94);
  letter-spacing: 0.08rem;
}

.screen-evolution__name {
  font-size: clamp(2rem, 4vw, 3rem);
}

.screen-evolution__seal {
  width: 4.9rem;
  height: 4.9rem;
  display: grid;
  place-items: center;
  border-radius: 50%;
  border: 1px solid rgba(240, 208, 135, 0.38);
  background:
    radial-gradient(circle at 30% 22%, rgba(255, 255, 255, 0.18), transparent 28%),
    linear-gradient(135deg, rgba(171, 123, 43, 0.92), rgba(112, 72, 20, 0.96));
  color: rgba(255, 247, 224, 0.94);
  font-family: var(--font-display);
  font-size: 1.8rem;
  box-shadow: 0 0 2rem rgba(240, 208, 135, 0.18);
}

.screen-evolution__hexagram-figure {
  padding: 1.2rem;
}

.screen-evolution__hexagram-figure .figure {
  min-width: 16rem;
  gap: 0.76rem;
}

.screen-evolution__hexagram-figure .figure__line {
  height: 1.05rem;
}

.screen-evolution__hexagram-name {
  font-size: clamp(2.3rem, 5vw, 4.2rem);
  line-height: 1.1;
}

.screen-evolution__progress {
  font-size: 0.92rem;
  opacity: 0;
}

.screen-evolution__matrix {
  display: grid;
  grid-template-columns: repeat(8, minmax(0, 1fr));
  gap: 0.7rem;
  padding: 1rem;
  overflow: auto;
  max-height: min(32vh, 19rem);
}

.evolution-cell {
  appearance: none;
  display: grid;
  gap: 0.2rem;
  align-content: start;
  min-width: 0;
  padding: 0.72rem 0.62rem;
  border-radius: 1rem;
  border: 1px solid rgba(202, 159, 72, 0.14);
  background: rgba(255, 250, 241, 0.68);
  color: rgba(40, 26, 16, 0.82);
  text-align: left;
  cursor: pointer;
  transition: transform 0.28s ease, border-color 0.28s ease, background 0.28s ease, color 0.28s ease, box-shadow 0.28s ease;
}

.evolution-cell:hover {
  transform: translateY(-2px);
}

.evolution-cell.is-compact {
  min-height: 4.9rem;
}

.evolution-cell.is-filled {
  color: rgba(39, 25, 12, 0.92);
  border-color: rgba(210, 167, 81, 0.42);
  background: linear-gradient(180deg, rgba(243, 224, 176, 0.96), rgba(223, 192, 123, 0.92));
}

.evolution-cell.is-selected {
  border-color: rgba(202, 159, 72, 0.52);
  box-shadow: 0 0 0 1px rgba(202, 159, 72, 0.18), 0 1rem 2rem rgba(60, 40, 22, 0.08);
}

.evolution-cell.is-active {
  transform: translateY(-2px) scale(1.03);
  border-color: rgba(255, 231, 171, 0.54);
  box-shadow: 0 0 1.4rem rgba(240, 208, 135, 0.18);
  color: rgba(32, 19, 10, 0.96);
  background: linear-gradient(180deg, rgba(188, 137, 52, 0.86), rgba(126, 84, 29, 0.92));
}

.screen-evolution__matrix .evolution-cell {
  border-color: rgba(240, 208, 135, 0.12);
  background: rgba(255, 250, 241, 0.05);
  color: rgba(255, 240, 209, 0.7);
}

.screen-evolution__matrix .evolution-cell.is-selected {
  background: rgba(240, 208, 135, 0.1);
  color: rgba(255, 244, 220, 0.92);
  box-shadow: 0 0 0 1px rgba(240, 208, 135, 0.12);
}

.screen-evolution__matrix .evolution-cell.is-filled {
  color: rgba(255, 245, 220, 0.9);
  border-color: rgba(240, 208, 135, 0.26);
  background: linear-gradient(180deg, rgba(120, 84, 37, 0.34), rgba(82, 56, 24, 0.42));
}

.screen-evolution__matrix .evolution-cell.is-active {
  color: rgba(32, 19, 10, 0.96);
}

.evolution-cell__order {
  font-size: 0.78rem;
  letter-spacing: 0.1rem;
}

.evolution-cell__name {
  font-family: var(--font-display);
  font-size: 0.98rem;
  letter-spacing: 0.05rem;
}

.evolution-cell__pair {
  font-size: 0.76rem;
  letter-spacing: 0.06rem;
  opacity: 0.78;
}

.screen-evolution__arena.is-animating .screen-evolution__stream--left {
  animation: evolutionStreamLeft 0.95s ease both;
}

.screen-evolution__arena.is-animating .screen-evolution__stream--right {
  animation: evolutionStreamRight 0.95s ease both;
}

.screen-evolution__arena.is-animating .screen-evolution__wing--upper {
  animation: evolutionWingLeft 1.12s cubic-bezier(0.2, 0.92, 0.28, 1) both;
}

.screen-evolution__arena.is-animating .screen-evolution__wing--lower {
  animation: evolutionWingRight 1.12s cubic-bezier(0.2, 0.92, 0.28, 1) both;
}

.screen-evolution__arena.is-animating .screen-evolution__burst {
  animation: evolutionBurst 0.92s 0.28s ease both;
}

.screen-evolution__arena.is-animating .screen-evolution__fusion {
  animation: evolutionFusionIn 0.96s 0.38s cubic-bezier(0.2, 0.92, 0.28, 1) both;
}

.screen-evolution__arena.is-animating .screen-evolution__seal {
  animation: evolutionSealPulse 0.72s 0.54s ease both;
}

.screen-evolution__arena.is-animating .screen-evolution__hexagram-figure {
  animation: evolutionFigureIn 0.72s 0.56s ease both;
}

.screen-evolution__arena.is-animating .screen-evolution__hexagram-name {
  animation: evolutionNameIn 0.76s 0.7s ease both;
}

.screen-evolution__arena.is-animating .screen-evolution__progress {
  animation: fadeSlide 0.55s 0.82s ease both;
}

.trigram-card {
  display: grid;
  gap: 0.9rem;
  padding: 0.9rem;
  border: 1px solid rgba(125, 91, 55, 0.16);
  border-radius: 1.2rem;
  background: linear-gradient(180deg, rgba(253, 249, 239, 0.9), rgba(247, 239, 221, 0.86));
  box-shadow: 0 1rem 2.2rem rgba(60, 40, 22, 0.08);
  cursor: pointer;
  color: inherit;
  opacity: 0;
  transform: translateY(12px);
  animation: fadeSlide 0.55s ease forwards;
  animation-delay: var(--trigram-card-delay, 0ms);
  transition: transform 0.35s ease, border-color 0.35s ease, box-shadow 0.35s ease;
}

.trigram-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow);
}

.trigram-card.is-active {
  border-color: rgba(202, 159, 72, 0.46);
  box-shadow: 0 1.1rem 2.4rem rgba(60, 40, 22, 0.1), 0 0 0 1px rgba(202, 159, 72, 0.14);
}

.trigram-card__meta {
  display: grid;
  gap: 0.18rem;
}

.trigram-card__name {
  margin: 0;
  font-family: var(--font-display);
  font-size: 1.3rem;
  letter-spacing: 0.08rem;
}

.trigram-card__full {
  margin: 0;
  color: var(--ink-soft);
  font-size: 0.92rem;
}

.trigram-card .figure {
  min-width: 7rem;
  gap: 0.5rem;
}

.figure--trigram .figure__line {
  height: 0.86rem;
}

.trigram-visual {
  position: relative;
  min-height: 100%;
  padding: 1.2rem;
  border-radius: 1.4rem;
  overflow: hidden;
  display: grid;
  place-items: center;
  isolation: isolate;
  background: linear-gradient(180deg, rgba(253, 246, 234, 0.78), rgba(239, 220, 176, 0.46));
}

.trigram-visual--card {
  min-height: 10rem;
  padding: 0.8rem;
  border-radius: 1rem;
}

.trigram-visual::before,
.trigram-visual::after {
  content: "";
  position: absolute;
  inset: auto;
  pointer-events: none;
}

.trigram-visual__glyph {
  position: relative;
  z-index: 2;
  font-family: var(--font-display);
  font-size: clamp(3.2rem, 7vw, 5.8rem);
  letter-spacing: 0.16rem;
  color: rgba(255, 249, 239, 0.92);
  text-shadow: 0 0.4rem 1.6rem rgba(91, 49, 9, 0.22);
}

.trigram-visual--card .trigram-visual__glyph {
  font-size: 2.3rem;
}

.trigram-visual__rune {
  position: absolute;
  border-radius: 999px;
  pointer-events: none;
}

.trigram-visual.is-qian {
  background:
    radial-gradient(circle at 28% 22%, rgba(255, 255, 255, 0.34), transparent 22%),
    linear-gradient(180deg, rgba(237, 215, 161, 0.5), rgba(154, 118, 57, 0.88));
}

.trigram-visual.is-qian::before {
  inset: 10% 14%;
  border-radius: 50%;
  border: 1px solid rgba(255, 243, 214, 0.42);
  animation: spinSlow 20s linear infinite;
}

.trigram-visual.is-qian::after {
  inset: 18% 22%;
  border-radius: 50%;
  border: 1px dashed rgba(255, 243, 214, 0.35);
  animation: spinSlow 14s linear infinite reverse;
}

.trigram-visual.is-qian .trigram-visual__rune--a,
.trigram-visual.is-qian .trigram-visual__rune--b,
.trigram-visual.is-qian .trigram-visual__rune--c {
  left: 50%;
  top: 50%;
  width: 1px;
  height: 82%;
  background: linear-gradient(180deg, transparent, rgba(255, 239, 200, 0.58), transparent);
  transform-origin: center;
}

.trigram-visual.is-qian .trigram-visual__rune--a { transform: translate(-50%, -50%) rotate(0deg); }
.trigram-visual.is-qian .trigram-visual__rune--b { transform: translate(-50%, -50%) rotate(60deg); }
.trigram-visual.is-qian .trigram-visual__rune--c { transform: translate(-50%, -50%) rotate(120deg); }

.trigram-visual.is-dui {
  background:
    linear-gradient(180deg, rgba(234, 214, 176, 0.22), rgba(135, 105, 68, 0.2)),
    radial-gradient(circle at 50% 18%, rgba(255, 250, 240, 0.36), transparent 22%),
    linear-gradient(180deg, rgba(121, 160, 170, 0.92), rgba(70, 115, 123, 0.92));
}

.trigram-visual.is-dui .trigram-visual__rune--a,
.trigram-visual.is-dui .trigram-visual__rune--b,
.trigram-visual.is-dui .trigram-visual__rune--c {
  left: 16%;
  right: 16%;
  height: 0.45rem;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.56), transparent);
  animation: rippleDrift 4.8s ease-in-out infinite;
}

.trigram-visual.is-dui .trigram-visual__rune--a { bottom: 24%; }
.trigram-visual.is-dui .trigram-visual__rune--b { bottom: 17%; animation-delay: 0.6s; }
.trigram-visual.is-dui .trigram-visual__rune--c { bottom: 10%; animation-delay: 1.2s; }

.trigram-visual.is-li {
  background:
    radial-gradient(circle at 50% 16%, rgba(255, 247, 208, 0.32), transparent 18%),
    linear-gradient(180deg, rgba(234, 133, 74, 0.94), rgba(121, 31, 20, 0.96));
}

.trigram-visual.is-li .trigram-visual__rune--a,
.trigram-visual.is-li .trigram-visual__rune--b,
.trigram-visual.is-li .trigram-visual__rune--c {
  bottom: 14%;
  width: 24%;
  height: 58%;
  background: radial-gradient(circle at 50% 70%, rgba(255, 245, 214, 0.72), rgba(255, 221, 132, 0.36) 42%, transparent 74%);
  clip-path: polygon(50% 0%, 72% 22%, 100% 70%, 68% 100%, 34% 78%, 0% 100%, 14% 48%);
  animation: flameRise 3.8s ease-in-out infinite;
}

.trigram-visual.is-li .trigram-visual__rune--a { left: 17%; }
.trigram-visual.is-li .trigram-visual__rune--b { left: 38%; animation-delay: 0.7s; }
.trigram-visual.is-li .trigram-visual__rune--c { left: 59%; animation-delay: 1.3s; }

.trigram-visual.is-zhen {
  background:
    linear-gradient(180deg, rgba(42, 54, 96, 0.42), transparent 38%),
    linear-gradient(180deg, rgba(109, 94, 141, 0.88), rgba(67, 56, 102, 0.94));
}

.trigram-visual.is-zhen .trigram-visual__rune--a,
.trigram-visual.is-zhen .trigram-visual__rune--b,
.trigram-visual.is-zhen .trigram-visual__rune--c {
  top: 10%;
  bottom: 10%;
  width: 0.7rem;
  background: linear-gradient(180deg, rgba(255, 247, 213, 0.12), rgba(255, 238, 181, 0.9), rgba(255, 247, 213, 0.12));
  clip-path: polygon(50% 0%, 90% 0%, 42% 38%, 88% 38%, 18% 100%, 32% 58%, 0% 58%);
  filter: drop-shadow(0 0 0.8rem rgba(255, 236, 175, 0.4));
  animation: lightningFlash 3.2s ease-in-out infinite;
}

.trigram-visual.is-zhen .trigram-visual__rune--a { left: 28%; }
.trigram-visual.is-zhen .trigram-visual__rune--b { left: 48%; animation-delay: 0.7s; }
.trigram-visual.is-zhen .trigram-visual__rune--c { left: 66%; animation-delay: 1.3s; }

.trigram-visual.is-xun {
  background:
    radial-gradient(circle at 30% 24%, rgba(255, 255, 255, 0.24), transparent 20%),
    linear-gradient(180deg, rgba(128, 154, 122, 0.94), rgba(63, 104, 76, 0.96));
}

.trigram-visual.is-xun .trigram-visual__rune--a,
.trigram-visual.is-xun .trigram-visual__rune--b,
.trigram-visual.is-xun .trigram-visual__rune--c {
  left: 14%;
  right: 14%;
  height: 0.55rem;
  border-radius: 999px;
  border: 1px solid rgba(240, 249, 223, 0.26);
  border-color: rgba(240, 249, 223, 0.26) transparent transparent transparent;
  animation: windSweep 4.5s ease-in-out infinite;
}

.trigram-visual.is-xun .trigram-visual__rune--a { top: 28%; }
.trigram-visual.is-xun .trigram-visual__rune--b { top: 44%; animation-delay: 0.8s; }
.trigram-visual.is-xun .trigram-visual__rune--c { top: 60%; animation-delay: 1.4s; }

.trigram-visual.is-kan {
  background:
    radial-gradient(circle at 50% 16%, rgba(255, 255, 255, 0.22), transparent 18%),
    linear-gradient(180deg, rgba(77, 139, 162, 0.94), rgba(27, 69, 96, 0.96));
}

.trigram-visual.is-kan .trigram-visual__rune--a,
.trigram-visual.is-kan .trigram-visual__rune--b,
.trigram-visual.is-kan .trigram-visual__rune--c {
  width: 1.1rem;
  height: 1.1rem;
  border-radius: 50%;
  background: radial-gradient(circle at 40% 30%, rgba(255, 255, 255, 0.8), rgba(200, 237, 255, 0.36) 52%, transparent 74%);
  animation: dropFloat 4.8s ease-in-out infinite;
}

.trigram-visual.is-kan .trigram-visual__rune--a { left: 22%; top: 36%; }
.trigram-visual.is-kan .trigram-visual__rune--b { left: 48%; top: 24%; animation-delay: 0.9s; }
.trigram-visual.is-kan .trigram-visual__rune--c { left: 70%; top: 42%; animation-delay: 1.6s; }

.trigram-visual.is-gen {
  background:
    linear-gradient(180deg, rgba(248, 238, 219, 0.16), transparent 34%),
    linear-gradient(180deg, rgba(120, 109, 123, 0.76), rgba(80, 72, 88, 0.96));
}

.trigram-visual.is-gen .trigram-visual__rune--a,
.trigram-visual.is-gen .trigram-visual__rune--b,
.trigram-visual.is-gen .trigram-visual__rune--c {
  bottom: 0;
  width: 36%;
  background: linear-gradient(180deg, rgba(241, 229, 202, 0.9), rgba(190, 162, 108, 0.72));
  clip-path: polygon(50% 0%, 100% 100%, 0% 100%);
  animation: mountainGlow 5.2s ease-in-out infinite;
}

.trigram-visual.is-gen .trigram-visual__rune--a { left: 4%; height: 42%; }
.trigram-visual.is-gen .trigram-visual__rune--b { left: 32%; height: 62%; animation-delay: 0.8s; }
.trigram-visual.is-gen .trigram-visual__rune--c { left: 60%; height: 50%; animation-delay: 1.4s; }

.trigram-visual.is-kun {
  background:
    linear-gradient(180deg, rgba(255, 247, 228, 0.22), transparent 26%),
    linear-gradient(180deg, rgba(171, 128, 74, 0.92), rgba(112, 80, 42, 0.96));
}

.trigram-visual.is-kun .trigram-visual__rune--a,
.trigram-visual.is-kun .trigram-visual__rune--b,
.trigram-visual.is-kun .trigram-visual__rune--c {
  left: 8%;
  right: 8%;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255, 238, 198, 0.58), transparent);
}

.trigram-visual.is-kun .trigram-visual__rune--a { top: 34%; box-shadow: 0 2.2rem 0 rgba(255, 238, 198, 0.32), 0 4.4rem 0 rgba(255, 238, 198, 0.22); }
.trigram-visual.is-kun .trigram-visual__rune--b { top: 48%; box-shadow: 0 2.2rem 0 rgba(255, 238, 198, 0.24); }
.trigram-visual.is-kun .trigram-visual__rune--c { top: 62%; }

.academy {
  isolation: isolate;
}

.academy__mist {
  position: absolute;
  width: 24rem;
  height: 24rem;
  border-radius: 50%;
  filter: blur(24px);
  pointer-events: none;
  opacity: 0.42;
}

.academy__mist--a {
  left: -5rem;
  top: -7rem;
  background: radial-gradient(circle, rgba(255, 255, 255, 0.34), transparent 72%);
  animation: washFloat 16s ease-in-out infinite;
}

.academy__mist--b {
  right: -6rem;
  bottom: -6rem;
  background: radial-gradient(circle, rgba(240, 208, 135, 0.24), transparent 72%);
  animation: washFloat 19s ease-in-out infinite reverse;
}

.academy__heading {
  display: flex;
  align-items: center;
  gap: 1rem;
  flex-wrap: wrap;
}

.academy__seal {
  width: 3.5rem;
  height: 3.5rem;
  display: grid;
  place-items: center;
  border: 1px solid rgba(157, 47, 32, 0.6);
  color: var(--vermillion);
  font-family: var(--font-display);
  font-size: 1.55rem;
  transform: rotate(-8deg);
  box-shadow: inset 0 0 0 0.28rem rgba(157, 47, 32, 0.06);
}

.academy__titles {
  display: grid;
  gap: 0.3rem;
}

.academy__label {
  margin: 0;
  color: var(--ink-soft);
  letter-spacing: 0.2rem;
}

.academy__body {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(220px, 260px) minmax(0, 1fr);
  gap: 1rem;
  align-items: start;
}

.study-nav {
  display: grid;
  gap: 0.75rem;
}

.study-nav__button {
  appearance: none;
  display: grid;
  gap: 0.35rem;
  width: 100%;
  padding: 1rem 1.05rem;
  border-radius: 1.25rem;
  border: 1px solid rgba(128, 93, 56, 0.14);
  background: rgba(255, 250, 241, 0.62);
  color: inherit;
  text-align: left;
  cursor: pointer;
  opacity: 0;
  transform: translateY(10px);
  animation: fadeSlide 0.55s ease forwards;
  animation-delay: var(--study-delay, 0ms);
  transition: transform 0.35s ease, border-color 0.35s ease, box-shadow 0.35s ease, background 0.35s ease;
}

.study-nav__button:hover {
  transform: translateY(-2px);
  box-shadow: 0 1rem 2rem rgba(60, 40, 22, 0.08);
}

.study-nav__button.is-active {
  border-color: rgba(202, 159, 72, 0.38);
  background: linear-gradient(180deg, rgba(255, 250, 241, 0.9), rgba(248, 239, 217, 0.88));
  box-shadow: 0 1.1rem 2.2rem rgba(60, 40, 22, 0.08), 0 0 0 1px rgba(202, 159, 72, 0.12);
}

.study-nav__label {
  color: var(--ink-soft);
  font-size: 0.82rem;
  letter-spacing: 0.16rem;
}

.study-nav__title {
  font-family: var(--font-display);
  font-size: 1.25rem;
  letter-spacing: 0.08rem;
}

.study-panel {
  min-width: 0;
}

.study-panel__article {
  position: relative;
  padding: 1.2rem;
  border-radius: 1.45rem;
  border: 1px solid rgba(128, 93, 56, 0.14);
  background: linear-gradient(180deg, rgba(253, 249, 239, 0.92), rgba(246, 238, 220, 0.88));
  box-shadow: 0 1rem 2.2rem rgba(60, 40, 22, 0.08);
  overflow: hidden;
}

.study-panel__article::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 14% 16%, rgba(255, 255, 255, 0.28), transparent 16%),
    linear-gradient(135deg, transparent 0 30%, rgba(157, 47, 32, 0.03) 48%, transparent 66%);
  pointer-events: none;
}

.study-panel__header {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  gap: 1rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid rgba(122, 89, 54, 0.12);
}

.study-panel__seal {
  width: 4.2rem;
  height: 4.2rem;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background:
    radial-gradient(circle at 30% 20%, rgba(255, 255, 255, 0.24), transparent 28%),
    linear-gradient(135deg, rgba(157, 47, 32, 0.96), rgba(121, 26, 19, 0.96));
  color: #fbf2df;
  font-family: var(--font-display);
  font-size: 1.15rem;
  letter-spacing: 0.08rem;
  box-shadow: 0 1rem 2rem rgba(125, 31, 23, 0.18);
}

.study-panel__titles {
  display: grid;
  gap: 0.4rem;
}

.study-panel__meta {
  margin: 0;
  color: var(--ink-soft);
  letter-spacing: 0.18rem;
}

.study-panel__title {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(1.8rem, 3.2vw, 2.8rem);
  letter-spacing: 0.1rem;
}

.study-panel__body {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 1rem;
  margin-top: 1rem;
  max-height: 38rem;
  padding-right: 0.5rem;
  overflow: auto;
}

.study-panel__body::-webkit-scrollbar {
  width: 0.65rem;
}

.study-panel__body::-webkit-scrollbar-thumb {
  border-radius: 999px;
  background: rgba(202, 159, 72, 0.28);
}

.study-panel__entry {
  padding: 1rem 1rem 1.1rem;
  border-radius: 1.15rem;
  background: rgba(255, 251, 243, 0.62);
  border: 1px solid rgba(202, 159, 72, 0.12);
  opacity: 0;
  transform: translateY(12px);
  animation: fadeSlide 0.55s ease forwards;
  animation-delay: var(--entry-delay, 0ms);
}

.study-panel__entry-title {
  margin: 0 0 0.7rem;
  font-size: 0.92rem;
  color: var(--ink-soft);
  letter-spacing: 0.18rem;
}

.study-panel__text {
  margin: 0;
  line-height: 1.9;
  color: rgba(27, 21, 16, 0.88);
}

.study-panel__text + .study-panel__text {
  margin-top: 0.6rem;
}

.guzhan-panel__body {
  display: grid;
  gap: 1rem;
}

.guzhan-case {
  position: relative;
  padding: 1.2rem 1.25rem 1.25rem;
  border-radius: 1.2rem;
  border: 1px solid rgba(157, 107, 62, 0.12);
  background: rgba(255, 251, 244, 0.88);
  box-shadow: 0 16px 40px rgba(128, 95, 58, 0.08);
  animation: fadeSlideUp 0.56s ease both;
  animation-delay: var(--entry-delay, 0ms);
}

.guzhan-case__meta {
  margin: 0;
  color: rgba(112, 83, 54, 0.62);
  font-size: 0.76rem;
  letter-spacing: 0.08em;
}

.guzhan-case__title {
  margin: 0.45rem 0 0;
  font-family: var(--font-display);
  font-size: 1.42rem;
  color: var(--ink-strong);
}

.guzhan-case__body {
  margin-top: 0.95rem;
}

.guzhan-case__text {
  margin: 0;
  color: rgba(63, 43, 24, 0.82);
  line-height: 1.95;
  text-indent: 2em;
}

.guzhan-case__text + .guzhan-case__text {
  margin-top: 0.9rem;
}

.study-videos {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 1rem;
  margin-top: 1.1rem;
}

.study-video {
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(320px, 0.92fr);
  gap: 1rem;
  padding: 1rem;
  border-radius: 1.35rem;
  background: linear-gradient(180deg, rgba(253, 249, 239, 0.94), rgba(247, 239, 221, 0.9));
  border: 1px solid rgba(125, 91, 55, 0.16);
  box-shadow: 0 1rem 2.2rem rgba(60, 40, 22, 0.08);
}

.study-video__media,
.study-video__overview {
  display: grid;
  gap: 0.8rem;
  align-content: start;
}

.study-video__frame {
  position: relative;
  overflow: hidden;
  border-radius: 1.25rem;
  border: 1px solid rgba(125, 91, 55, 0.18);
  background: linear-gradient(180deg, rgba(22, 15, 11, 0.98), rgba(15, 10, 8, 0.98));
  box-shadow: 0 1rem 2rem rgba(28, 18, 10, 0.16);
}

.study-video__frame::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 14% 16%, rgba(255, 255, 255, 0.1), transparent 18%),
    linear-gradient(135deg, transparent 0 28%, rgba(255, 214, 143, 0.06) 48%, transparent 66%);
  pointer-events: none;
}

.study-video__player {
  display: block;
  width: 100%;
  aspect-ratio: 16 / 9;
  background: #120c09;
}

.study-video__caption,
.study-video__eyebrow,
.study-video__chapter-hint,
.study-video-shelf__meta {
  margin: 0;
  color: var(--ink-soft);
}

.study-video__caption {
  font-size: 0.9rem;
  letter-spacing: 0.08rem;
}

.study-video__title,
.study-video-shelf__title {
  margin: 0;
  font-family: var(--font-display);
}

.study-video__title {
  font-size: clamp(1.85rem, 3.1vw, 2.55rem);
  letter-spacing: 0.08rem;
}

.study-video__subtitle,
.study-video__summary,
.study-video__chapter-title {
  margin: 0;
}

.study-video__subtitle {
  font-size: 1rem;
  color: rgba(27, 21, 16, 0.72);
}

.study-video__summary {
  line-height: 1.88;
  color: rgba(27, 21, 16, 0.86);
}

.study-video__chips {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
}

.study-video__chip {
  padding: 0.4rem 0.78rem;
  border-radius: 999px;
  background: rgba(255, 250, 241, 0.82);
  border: 1px solid rgba(128, 93, 56, 0.12);
  color: var(--study-video-accent, #8c3328);
  font-size: 0.88rem;
}

.study-video__chapter-head,
.study-video-shelf__head {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 1rem;
}

.study-video__chapter-title,
.study-video-shelf__title {
  font-size: 1.22rem;
  letter-spacing: 0.08rem;
}

.study-video__chapters {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.7rem;
}

.study-video__chapter,
.study-video-card {
  appearance: none;
  width: 100%;
  border-radius: 1.05rem;
  border: 1px solid rgba(128, 93, 56, 0.14);
  background: rgba(255, 250, 241, 0.74);
  color: inherit;
  text-align: left;
  cursor: pointer;
  transition: transform 0.28s ease, border-color 0.28s ease, box-shadow 0.28s ease, background 0.28s ease;
}

.study-video__chapter {
  display: grid;
  gap: 0.35rem;
  padding: 0.85rem 0.9rem;
}

.study-video__chapter:hover,
.study-video-card:hover {
  transform: translateY(-2px);
}

.study-video__chapter.is-active,
.study-video-card.is-active {
  border-color: var(--study-video-accent, #8c3328);
  box-shadow: 0 1rem 2.2rem rgba(60, 40, 22, 0.08), 0 0 0 1px var(--study-video-accent, #8c3328);
  background: linear-gradient(180deg, rgba(255, 251, 244, 0.96), rgba(249, 238, 222, 0.94));
}

.study-video__chapter-meta,
.study-video-card__label {
  font-size: 0.78rem;
  letter-spacing: 0.16rem;
  color: var(--ink-soft);
}

.study-video__chapter-name,
.study-video-card__title {
  font-size: 1rem;
  color: rgba(27, 21, 16, 0.94);
}

.study-video__chapter-note,
.study-video-card__meta {
  color: rgba(27, 21, 16, 0.72);
  line-height: 1.65;
}

.study-video-card {
  display: grid;
  gap: 0.4rem;
  padding: 0.9rem 1rem;
  opacity: 0;
  transform: translateY(12px);
  animation: fadeSlide 0.55s ease forwards;
  animation-delay: var(--study-video-delay, 0ms);
}

.study-video-card__title {
  margin: 0;
  font-family: var(--font-display);
  letter-spacing: 0.06rem;
}

.study-video-card__meta {
  margin: 0;
  font-size: 0.9rem;
}

.study-video-shelf {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.8rem;
}

@media (max-width: 1160px) {
  .study-video {
    grid-template-columns: 1fr;
  }

  .study-video__chapters,
  .study-video-shelf {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 760px) {
  .study-video__chapter-head,
  .study-video-shelf__head {
    flex-direction: column;
    align-items: start;
  }

  .study-video__chapters,
  .study-video-shelf {
    grid-template-columns: 1fr;
  }
}

.study-trigrams {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 1rem;
  margin-top: 1.2rem;
}

.study-trigrams__title {
  margin: 0;
  font-family: var(--font-display);
  font-size: 1.45rem;
  letter-spacing: 0.12rem;
}

.study-trigrams__grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1rem;
}

.study-trigram-detail {
  position: relative;
  z-index: 1;
}

.study-trigram-detail__panel {
  display: grid;
  grid-template-columns: minmax(220px, 280px) minmax(0, 1fr);
  gap: 1rem;
  padding: 1rem;
  border-radius: 1.35rem;
  background: linear-gradient(180deg, rgba(253, 249, 239, 0.92), rgba(247, 239, 221, 0.88));
  border: 1px solid rgba(125, 91, 55, 0.16);
  box-shadow: 0 1rem 2.2rem rgba(60, 40, 22, 0.08);
}

.study-trigram-detail__visual {
  min-height: 14rem;
}

.study-trigram-detail__copy {
  display: grid;
  gap: 0.75rem;
  align-content: center;
}

.study-trigram-detail__meta {
  margin: 0;
  color: var(--ink-soft);
  letter-spacing: 0.18rem;
}

.study-trigram-detail__title {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(1.6rem, 3vw, 2.3rem);
  letter-spacing: 0.08rem;
}

.study-trigram-detail__figure .figure {
  min-width: 10rem;
  gap: 0.7rem;
}

.study-trigram-detail__figure .figure__line {
  height: 0.95rem;
}

.study-trigram-detail__text {
  margin: 0;
  line-height: 1.9;
  color: rgba(27, 21, 16, 0.86);
}

.study-trigram {
  appearance: none;
  display: grid;
  gap: 0.9rem;
  width: 100%;
  padding: 1rem;
  border-radius: 1.2rem;
  background: linear-gradient(180deg, rgba(253, 249, 239, 0.9), rgba(247, 239, 221, 0.86));
  border: 1px solid rgba(125, 91, 55, 0.16);
  box-shadow: 0 1rem 2.2rem rgba(60, 40, 22, 0.08);
  opacity: 0;
  transform: translateY(14px);
  animation: fadeSlide 0.55s ease forwards;
  animation-delay: var(--trigram-delay, 0ms);
  text-align: left;
  color: inherit;
  cursor: pointer;
  transition: transform 0.35s ease, border-color 0.35s ease, box-shadow 0.35s ease;
}

.study-trigram:hover {
  transform: translateY(-3px);
}

.study-trigram.is-active {
  border-color: rgba(202, 159, 72, 0.42);
  box-shadow: 0 1.1rem 2.2rem rgba(60, 40, 22, 0.08), 0 0 0 1px rgba(202, 159, 72, 0.12);
}

.study-trigram__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}

.study-trigram__title {
  margin: 0;
  font-family: var(--font-display);
  font-size: 1.3rem;
  letter-spacing: 0.08rem;
}

.study-trigram__text {
  margin: 0;
  line-height: 1.82;
  color: rgba(27, 21, 16, 0.86);
}

.academy-plus {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 1.2rem;
  margin-top: 1.3rem;
}

.academy-plus__row {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

.case-shelf,
.body-use,
.relation-map,
.scroll-reader {
  position: relative;
  border-radius: 1.45rem;
  border: 1px solid rgba(125, 91, 55, 0.14);
  background: linear-gradient(180deg, rgba(253, 249, 239, 0.92), rgba(246, 238, 220, 0.88));
  box-shadow: 0 1rem 2.2rem rgba(60, 40, 22, 0.08);
  overflow: hidden;
}

.case-shelf::before,
.body-use::before,
.relation-map::before,
.scroll-reader::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 14% 16%, rgba(255, 255, 255, 0.26), transparent 16%),
    linear-gradient(135deg, transparent 0 28%, rgba(157, 47, 32, 0.03) 46%, transparent 66%);
  pointer-events: none;
}

.case-shelf__head,
.body-use__head,
.relation-map__head,
.scroll-reader__head {
  position: relative;
  z-index: 1;
  padding: 1rem 1rem 0;
}

.case-shelf__title,
.body-use__title,
.relation-map__title,
.scroll-reader__title {
  margin: 0;
  font-family: var(--font-display);
  font-size: 1.45rem;
  letter-spacing: 0.1rem;
}

.case-shelf__body,
.scroll-reader__body {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(220px, 260px) minmax(0, 1fr);
  gap: 1rem;
  padding: 1rem;
  align-items: start;
}

.case-nav,
.scroll-nav {
  display: grid;
  gap: 0.75rem;
}

.case-nav__button,
.scroll-nav__button {
  appearance: none;
  display: grid;
  gap: 0.32rem;
  width: 100%;
  padding: 0.95rem 1rem;
  border-radius: 1.15rem;
  border: 1px solid rgba(128, 93, 56, 0.14);
  background: rgba(255, 250, 241, 0.62);
  color: inherit;
  text-align: left;
  cursor: pointer;
  opacity: 0;
  transform: translateY(10px);
  animation: fadeSlide 0.55s ease forwards;
  transition: transform 0.35s ease, border-color 0.35s ease, box-shadow 0.35s ease, background 0.35s ease;
}

.case-nav__button { animation-delay: var(--case-delay, 0ms); }
.scroll-nav__button { animation-delay: var(--scroll-delay, 0ms); }

.case-nav__button:hover,
.scroll-nav__button:hover {
  transform: translateY(-2px);
  box-shadow: 0 1rem 2rem rgba(60, 40, 22, 0.08);
}

.case-nav__button.is-active,
.scroll-nav__button.is-active {
  border-color: rgba(202, 159, 72, 0.38);
  background: linear-gradient(180deg, rgba(255, 250, 241, 0.9), rgba(248, 239, 217, 0.88));
  box-shadow: 0 1.1rem 2.2rem rgba(60, 40, 22, 0.08), 0 0 0 1px rgba(202, 159, 72, 0.12);
}

.case-nav__label,
.scroll-nav__label {
  color: var(--ink-soft);
  font-size: 0.8rem;
  letter-spacing: 0.16rem;
}

.case-nav__title,
.scroll-nav__title {
  font-family: var(--font-display);
  font-size: 1.18rem;
}

.case-panel,
.scroll-panel {
  min-width: 0;
}

.case-panel__article,
.scroll-panel__article {
  position: relative;
  padding: 1.1rem;
  border-radius: 1.3rem;
  border: 1px solid rgba(128, 93, 56, 0.14);
  background: rgba(255, 251, 243, 0.78);
  min-height: 100%;
}

.case-panel__header,
.scroll-panel__header {
  display: grid;
  gap: 0.35rem;
  padding-bottom: 0.85rem;
  border-bottom: 1px solid rgba(122, 89, 54, 0.12);
}

.case-panel__meta,
.scroll-panel__label {
  margin: 0;
  color: var(--ink-soft);
  letter-spacing: 0.16rem;
}

.case-panel__title,
.scroll-panel__title {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(1.55rem, 3vw, 2.3rem);
  letter-spacing: 0.08rem;
}

.case-panel__figures {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.8rem;
  margin-top: 1rem;
}

.case-card {
  display: grid;
  gap: 0.55rem;
  padding: 0.85rem;
  border-radius: 1.05rem;
  border: 1px solid rgba(202, 159, 72, 0.12);
  background: rgba(255, 251, 243, 0.74);
  opacity: 0;
  transform: translateY(10px);
  animation: fadeSlide 0.55s ease forwards;
  animation-delay: var(--case-card-delay, 0ms);
}

.case-card__label {
  margin: 0;
  color: var(--ink-soft);
  letter-spacing: 0.14rem;
}

.case-card__name {
  margin: 0;
  font-family: var(--font-display);
  font-size: 1.08rem;
}

.case-card__figure .figure {
  min-width: 6.8rem;
  gap: 0.46rem;
}

.case-card__figure .figure__line {
  height: 0.7rem;
}

.case-panel__body {
  display: grid;
  gap: 0.85rem;
  margin-top: 1rem;
}

.case-panel__text {
  margin: 0;
  line-height: 1.92;
  color: rgba(27, 21, 16, 0.88);
  opacity: 0;
  transform: translateY(10px);
  animation: fadeSlide 0.55s ease forwards;
  animation-delay: var(--case-text-delay, 0ms);
}

.body-use__panel {
  position: relative;
  z-index: 1;
  padding: 1rem;
}

.body-use__article {
  display: grid;
  gap: 1rem;
}

.body-use__orbit {
  position: relative;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.8rem;
  align-items: center;
}

.body-use__orbit::before {
  content: "";
  position: absolute;
  inset: 50% 18%;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(202, 159, 72, 0.52), transparent);
}

.body-use__wing,
.body-use__center {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 0.5rem;
  justify-items: center;
  text-align: center;
  padding: 1rem;
  border-radius: 1.2rem;
  border: 1px solid rgba(202, 159, 72, 0.12);
  background: rgba(255, 251, 243, 0.72);
}

.body-use__meta,
.body-use__element {
  margin: 0;
  color: var(--ink-soft);
  letter-spacing: 0.16rem;
}

.body-use__name {
  margin: 0;
  font-family: var(--font-display);
  font-size: 1.5rem;
}

.body-use__figure .figure {
  min-width: 7rem;
  gap: 0.5rem;
}

.body-use__figure .figure__line {
  height: 0.76rem;
}

.body-use__seal {
  width: 4.4rem;
  height: 4.4rem;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background:
    radial-gradient(circle at 30% 20%, rgba(255, 255, 255, 0.24), transparent 28%),
    linear-gradient(135deg, rgba(157, 47, 32, 0.96), rgba(121, 26, 19, 0.96));
  color: #fbf2df;
  font-family: var(--font-display);
  font-size: 1.4rem;
  box-shadow: 0 1rem 2rem rgba(125, 31, 23, 0.16);
  animation: sealBeat 4.8s ease-in-out infinite;
}

.body-use__line {
  margin: 0;
  line-height: 1.8;
  color: rgba(27, 21, 16, 0.86);
}

.body-use__quotes {
  display: grid;
  gap: 0.8rem;
}

.body-use__quote {
  margin: 0;
  padding: 0.95rem 1rem;
  border-radius: 1rem;
  background: rgba(255, 251, 243, 0.74);
  border: 1px solid rgba(202, 159, 72, 0.12);
  line-height: 1.9;
  opacity: 0;
  transform: translateY(10px);
  animation: fadeSlide 0.55s ease forwards;
  animation-delay: var(--body-quote-delay, 0ms);
}

.daoyi-hall {
  --daoyi-accent: #6a5b8f;
  --daoyi-deep: #3a2f57;
  --daoyi-wash: rgba(106, 91, 143, 0.15);
  isolation: isolate;
}

.daoyi-hall__mist {
  position: absolute;
  width: 26rem;
  height: 26rem;
  border-radius: 50%;
  filter: blur(28px);
  pointer-events: none;
  opacity: 0.42;
}

.daoyi-hall__mist--a {
  left: -8rem;
  top: -7rem;
  background: radial-gradient(circle, rgba(228, 220, 255, 0.34), transparent 72%);
  animation: washFloat 18s ease-in-out infinite;
}

.daoyi-hall__mist--b {
  right: -8rem;
  bottom: -7rem;
  background: radial-gradient(circle, rgba(197, 180, 234, 0.28), transparent 72%);
  animation: washFloat 20s ease-in-out infinite reverse;
}

.daoyi-hall__heading {
  display: flex;
  align-items: center;
  gap: 1rem;
  flex-wrap: wrap;
}

.daoyi-hall__seal {
  width: 3.8rem;
  height: 3.8rem;
  display: grid;
  place-items: center;
  border-radius: 1rem;
  border: 1px solid rgba(106, 91, 143, 0.22);
  color: var(--daoyi-deep);
  font-family: var(--font-display);
  font-size: 1.6rem;
  transform: rotate(-6deg);
  box-shadow:
    inset 0 0 0 0.28rem rgba(106, 91, 143, 0.08),
    0 1rem 2rem rgba(60, 40, 22, 0.08);
}

.daoyi-hall__titles {
  display: grid;
  gap: 0.34rem;
}

.daoyi-hall__label,
.daoyi-hall__note,
.daoyi-nav__note,
.daoyi-guide__label,
.daoyi-guide__note,
.daoyi-overview__label,
.daoyi-overview__note,
.daoyi-overview__metric-label,
.daoyi-reader__label,
.daoyi-reader__cue,
.daoyi-detail__label,
.daoyi-detail__note,
.daoyi-chapter-grid__cue,
.daoyi-chapter-card__meta,
.daoyi-chapter-card__excerpt {
  margin: 0;
  color: var(--ink-soft);
}

.daoyi-hall__label,
.daoyi-overview__label,
.daoyi-reader__label,
.daoyi-detail__label,
.daoyi-guide__label {
  letter-spacing: 0.18rem;
}

.daoyi-hall__body {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(220px, 260px) minmax(0, 1fr);
  gap: 1rem;
  align-items: start;
}

.daoyi-hall__sidebar {
  display: grid;
  gap: 0.9rem;
}

.daoyi-nav {
  display: grid;
  gap: 0.75rem;
}

.daoyi-nav__button {
  appearance: none;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 0.8rem;
  align-items: center;
  width: 100%;
  padding: 1rem 1.05rem;
  border-radius: 1.25rem;
  border: 1px solid rgba(128, 93, 56, 0.14);
  background: rgba(255, 250, 241, 0.62);
  text-align: left;
  cursor: pointer;
  opacity: 0;
  transform: translateY(10px);
  animation: fadeSlide 0.55s ease forwards;
  animation-delay: var(--daoyi-delay, 0ms);
  transition: transform 0.35s ease, border-color 0.35s ease, box-shadow 0.35s ease, background 0.35s ease;
}

.daoyi-nav__button:hover {
  transform: translateY(-2px);
  box-shadow: 0 1rem 2rem rgba(60, 40, 22, 0.08);
}

.daoyi-nav__button.is-active {
  border-color: rgba(106, 91, 143, 0.28);
  background: linear-gradient(180deg, rgba(235, 229, 250, 0.92), rgba(248, 239, 217, 0.9));
  box-shadow: 0 1.1rem 2.2rem rgba(60, 40, 22, 0.08);
}

.daoyi-nav__seal {
  width: 2.45rem;
  height: 2.45rem;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: linear-gradient(135deg, rgba(106, 91, 143, 0.96), rgba(58, 47, 87, 0.98));
  color: #fbf2df;
  font-family: var(--font-display);
  font-size: 1rem;
  box-shadow: 0 0.9rem 1.8rem rgba(60, 40, 22, 0.12);
}

.daoyi-nav__copy {
  display: grid;
  gap: 0.22rem;
}

.daoyi-nav__title {
  font-family: var(--font-display);
  font-size: 1.16rem;
}

.daoyi-nav__note {
  font-size: 0.82rem;
  letter-spacing: 0.12rem;
}

.daoyi-guide {
  padding: 1rem 1.05rem;
  border-radius: 1.25rem;
  border: 1px solid rgba(128, 93, 56, 0.14);
  background: rgba(255, 251, 243, 0.72);
  display: grid;
  gap: 0.7rem;
}

.daoyi-guide__title {
  margin: 0;
  font-family: var(--font-display);
  font-size: 1.36rem;
}

.daoyi-guide__note {
  line-height: 1.82;
}

.daoyi-guide__stats {
  display: grid;
  gap: 0.65rem;
}

.daoyi-guide__stat {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  padding: 0.72rem 0.8rem;
  border-radius: 0.95rem;
  background: rgba(247, 241, 228, 0.82);
  border: 1px solid rgba(106, 91, 143, 0.12);
}

.daoyi-guide__stat span {
  color: var(--ink-soft);
  letter-spacing: 0.12rem;
}

.daoyi-guide__stat strong {
  font-family: var(--font-display);
  font-size: 1rem;
}

.daoyi-guide__path {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
}

.daoyi-guide__chip {
  display: inline-flex;
  padding: 0.35rem 0.72rem;
  border-radius: 999px;
  background: rgba(239, 231, 252, 0.72);
  border: 1px solid rgba(106, 91, 143, 0.14);
  color: var(--daoyi-deep);
  font-size: 0.82rem;
}

.daoyi-panel {
  min-width: 0;
}

.daoyi-panel__stack {
  display: grid;
  gap: 1rem;
}

.daoyi-reader-layout,
.daoyi-detail-layout {
  display: grid;
  grid-template-columns: minmax(15rem, 18.5rem) minmax(0, 1fr);
  gap: 1rem;
  align-items: start;
}

.daoyi-rail {
  position: sticky;
  top: calc(0.8rem + var(--safe-top));
  display: grid;
  gap: 0.85rem;
  padding: 1rem;
  border-radius: 1.3rem;
  border: 1px solid rgba(128, 93, 56, 0.14);
  background: linear-gradient(180deg, rgba(253, 249, 239, 0.92), rgba(246, 238, 220, 0.88));
  box-shadow: 0 1rem 2.2rem rgba(60, 40, 22, 0.08);
}

.daoyi-rail__head {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 0.8rem;
  align-items: start;
}

.daoyi-rail__seal {
  width: 2.55rem;
  height: 2.55rem;
  display: grid;
  place-items: center;
  border-radius: 0.9rem;
  background: linear-gradient(135deg, rgba(106, 91, 143, 0.96), rgba(58, 47, 87, 0.98));
  color: #fbf2df;
  font-family: var(--font-display);
  font-size: 1.05rem;
  box-shadow: 0 0.9rem 1.8rem rgba(60, 40, 22, 0.12);
}

.daoyi-rail__copy {
  display: grid;
  gap: 0.22rem;
}

.daoyi-rail__label,
.daoyi-rail__note,
.daoyi-reader__source {
  margin: 0;
  color: var(--ink-soft);
}

.daoyi-rail__label {
  letter-spacing: 0.16rem;
}

.daoyi-rail__title {
  margin: 0;
  font-family: var(--font-display);
  font-size: 1.24rem;
}

.daoyi-rail__note {
  line-height: 1.72;
  font-size: 0.92rem;
}

.daoyi-rail__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.daoyi-overview,
.daoyi-reader,
.daoyi-detail {
  position: relative;
  padding: 1.15rem;
  border-radius: 1.45rem;
  border: 1px solid rgba(128, 93, 56, 0.14);
  background: linear-gradient(180deg, rgba(253, 249, 239, 0.92), rgba(246, 238, 220, 0.88));
  box-shadow: 0 1rem 2.2rem rgba(60, 40, 22, 0.08);
  overflow: hidden;
}

.daoyi-overview::before,
.daoyi-reader::before,
.daoyi-detail::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 14% 16%, rgba(255, 255, 255, 0.28), transparent 16%),
    linear-gradient(135deg, transparent 0 30%, rgba(106, 91, 143, 0.08) 48%, transparent 66%);
  pointer-events: none;
}

.daoyi-overview__header,
.daoyi-reader__header,
.daoyi-detail__header {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  gap: 1rem;
  flex-wrap: wrap;
}

.daoyi-overview__seal,
.daoyi-detail__seal {
  width: 3.8rem;
  height: 3.8rem;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: linear-gradient(135deg, rgba(106, 91, 143, 0.96), rgba(58, 47, 87, 0.98));
  color: #fbf2df;
  font-family: var(--font-display);
  font-size: 1.18rem;
  box-shadow: 0 1rem 2rem rgba(60, 40, 22, 0.12);
}

.daoyi-overview__titles,
.daoyi-detail__titles,
.daoyi-reader__meta {
  display: grid;
  gap: 0.35rem;
}

.daoyi-overview__title,
.daoyi-reader__title,
.daoyi-detail__title {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(1.7rem, 3vw, 2.55rem);
}

.daoyi-overview__metrics {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(9rem, 1fr));
  gap: 0.8rem;
  margin-top: 1rem;
}

.daoyi-overview__metric {
  padding: 0.9rem 0.95rem;
  border-radius: 1.15rem;
  background: rgba(255, 251, 243, 0.7);
  border: 1px solid rgba(106, 91, 143, 0.12);
  display: grid;
  gap: 0.16rem;
}

.daoyi-overview__metric-value {
  font-family: var(--font-display);
  font-size: 1rem;
}

.daoyi-tag {
  display: inline-flex;
  align-items: center;
  padding: 0.36rem 0.72rem;
  border-radius: 999px;
  border: 1px solid rgba(106, 91, 143, 0.12);
  background: rgba(255, 251, 243, 0.86);
  color: rgba(27, 21, 16, 0.82);
  font-size: 0.82rem;
}

.daoyi-tag--theme {
  background: rgba(235, 229, 250, 0.86);
  color: var(--daoyi-deep);
}

.daoyi-tag--group {
  background: rgba(244, 235, 214, 0.9);
  color: rgba(88, 63, 27, 0.92);
}

.daoyi-tag.is-button {
  appearance: none;
  cursor: pointer;
}

.daoyi-chapter-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(8.2rem, 1fr));
  gap: 0.7rem;
  max-height: 22rem;
  overflow: auto;
  padding-right: 0.35rem;
}

.daoyi-chapter-grid__button,
.daoyi-select-grid__button,
.daoyi-reader__jump,
.daoyi-chapter-card {
  appearance: none;
  border: 1px solid rgba(128, 93, 56, 0.14);
  transition: transform 0.24s ease, border-color 0.24s ease, box-shadow 0.24s ease;
}

.daoyi-chapter-grid__button {
  min-height: 5.8rem;
  padding: 0.8rem 0.82rem;
  border-radius: 1rem;
  background: rgba(255, 251, 243, 0.76);
  text-align: left;
  display: grid;
  gap: 0.35rem;
  cursor: pointer;
}

.daoyi-chapter-grid__button:hover,
.daoyi-select-grid__button:hover,
.daoyi-reader__jump:hover,
.daoyi-chapter-card:hover {
  transform: translateY(-2px);
  border-color: rgba(106, 91, 143, 0.24);
  box-shadow: 0 0.9rem 1.8rem rgba(60, 40, 22, 0.08);
}

.daoyi-chapter-grid__button.is-active,
.daoyi-select-grid__button.is-active {
  border-color: rgba(106, 91, 143, 0.28);
  background: linear-gradient(180deg, rgba(235, 229, 250, 0.92), rgba(248, 239, 217, 0.9));
}

.daoyi-chapter-grid__no {
  font-family: var(--font-display);
  font-size: 1rem;
}

.daoyi-chapter-grid__cue {
  line-height: 1.62;
  font-size: 0.86rem;
}

.daoyi-reader__tags {
  position: relative;
  z-index: 1;
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
}

.daoyi-reader__body {
  position: relative;
  z-index: 1;
  margin-top: 1rem;
  display: grid;
  gap: 0.85rem;
}

.daoyi-reader__source {
  letter-spacing: 0.12rem;
}

.daoyi-reader__paragraph {
  margin: 0;
  padding: 0.95rem 1rem;
  border-radius: 1rem;
  background: rgba(255, 251, 243, 0.72);
  border: 1px solid rgba(106, 91, 143, 0.1);
  line-height: 1.92;
  font-size: 1.03rem;
}

.daoyi-reader__footer {
  position: relative;
  z-index: 1;
  display: flex;
  flex-wrap: wrap;
  gap: 0.7rem;
  margin-top: 1rem;
}

.daoyi-reader__jump {
  padding: 0.55rem 0.95rem;
  border-radius: 999px;
  background: rgba(255, 251, 243, 0.86);
  cursor: pointer;
}

.daoyi-select-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.8rem;
}

.daoyi-select-grid__button {
  padding: 0.95rem 1rem;
  border-radius: 1.15rem;
  background: rgba(255, 251, 243, 0.76);
  text-align: left;
  display: grid;
  gap: 0.3rem;
  cursor: pointer;
}

.daoyi-select-grid__seal {
  width: 2rem;
  height: 2rem;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: rgba(106, 91, 143, 0.14);
  color: var(--daoyi-deep);
  font-family: var(--font-display);
}

.daoyi-select-grid__title {
  font-family: var(--font-display);
  font-size: 1.14rem;
}

.daoyi-select-grid__note {
  color: var(--ink-soft);
  line-height: 1.68;
  font-size: 0.88rem;
}

.daoyi-detail__quote {
  position: relative;
  z-index: 1;
  margin: 1rem 0 0;
  padding: 1rem 1.05rem;
  border-radius: 1.2rem;
  background: rgba(255, 251, 243, 0.76);
  border: 1px solid rgba(106, 91, 143, 0.12);
  font-family: var(--font-display);
  line-height: 1.82;
}

.daoyi-detail__hex {
  position: relative;
  z-index: 1;
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
  margin-top: 0.95rem;
}

.daoyi-detail__stats {
  position: relative;
  z-index: 1;
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
  margin-top: 0.8rem;
}

.daoyi-detail__chapters {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(15rem, 1fr));
  gap: 0.8rem;
  margin-top: 1rem;
}

.daoyi-chapter-card {
  padding: 0.95rem 1rem;
  border-radius: 1.1rem;
  background: rgba(255, 251, 243, 0.76);
  cursor: pointer;
}

.daoyi-chapter-card__title {
  margin: 0.32rem 0 0;
  font-family: var(--font-display);
  font-size: 1.08rem;
}

.daoyi-chapter-card__excerpt {
  margin-top: 0.68rem;
  line-height: 1.78;
}

.daoyi-chapter-card__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  margin-top: 0.7rem;
}

.culture-hall {
  --culture-accent: #7b8756;
  --culture-deep: #455236;
  --culture-wash: rgba(123, 135, 86, 0.16);
  isolation: isolate;
}

.culture-hall__mist {
  position: absolute;
  width: 24rem;
  height: 24rem;
  border-radius: 50%;
  filter: blur(24px);
  pointer-events: none;
  opacity: 0.4;
}

.culture-hall__mist--a {
  left: -5rem;
  top: -7rem;
  background: radial-gradient(circle, color-mix(in srgb, var(--culture-accent) 18%, rgba(255, 255, 255, 0.32)), transparent 72%);
  animation: washFloat 16s ease-in-out infinite;
}

.culture-hall__mist--b {
  right: -6rem;
  bottom: -6rem;
  background: radial-gradient(circle, color-mix(in srgb, var(--culture-accent) 20%, rgba(240, 208, 135, 0.22)), transparent 72%);
  animation: washFloat 19s ease-in-out infinite reverse;
}

.culture-hall__heading {
  display: flex;
  align-items: center;
  gap: 1rem;
  flex-wrap: wrap;
}

.culture-hall__seal {
  width: 3.6rem;
  height: 3.6rem;
  display: grid;
  place-items: center;
  border-radius: 1rem;
  border: 1px solid color-mix(in srgb, var(--culture-accent) 72%, rgba(157, 47, 32, 0.26));
  color: var(--culture-deep);
  font-family: var(--font-display);
  font-size: 1.5rem;
  transform: rotate(-7deg);
  box-shadow:
    inset 0 0 0 0.28rem color-mix(in srgb, var(--culture-wash) 65%, rgba(255, 255, 255, 0)),
    0 0.9rem 1.8rem rgba(60, 40, 22, 0.08);
}

.culture-hall__titles {
  display: grid;
  gap: 0.32rem;
}

.culture-hall__label,
.culture-hall__note,
.culture-nav__label,
.culture-card__meta,
.culture-card__note,
.culture-panel__meta,
.culture-panel__note,
.culture-panel__quote-source,
.culture-panel__metric-label,
.culture-panel__bridge-text {
  margin: 0;
  color: var(--ink-soft);
}

.culture-hall__label,
.culture-panel__meta {
  letter-spacing: 0.18rem;
}

.culture-hall__body {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(220px, 260px) minmax(0, 1fr);
  gap: 1rem;
  align-items: start;
}

.culture-hall__sidebar {
  display: grid;
  gap: 0.9rem;
}

.culture-nav {
  display: grid;
  gap: 0.75rem;
}

.culture-nav__button {
  appearance: none;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 0.8rem;
  align-items: center;
  width: 100%;
  padding: 1rem 1.05rem;
  border-radius: 1.25rem;
  border: 1px solid rgba(128, 93, 56, 0.14);
  background: rgba(255, 250, 241, 0.62);
  color: inherit;
  text-align: left;
  cursor: pointer;
  opacity: 0;
  transform: translateY(10px);
  animation: fadeSlide 0.55s ease forwards;
  animation-delay: var(--culture-delay, 0ms);
  transition: transform 0.35s ease, border-color 0.35s ease, box-shadow 0.35s ease, background 0.35s ease;
}

.culture-nav__button:hover {
  transform: translateY(-2px);
  box-shadow: 0 1rem 2rem rgba(60, 40, 22, 0.08);
}

.culture-nav__button.is-active {
  border-color: color-mix(in srgb, var(--culture-accent) 44%, rgba(202, 159, 72, 0.2));
  background: linear-gradient(180deg, color-mix(in srgb, var(--culture-wash) 52%, rgba(255, 250, 241, 0.9)), rgba(248, 239, 217, 0.9));
  box-shadow:
    0 1.1rem 2.2rem rgba(60, 40, 22, 0.08),
    0 0 0 1px color-mix(in srgb, var(--culture-accent) 20%, rgba(202, 159, 72, 0.12));
}

.culture-nav__seal {
  width: 2.45rem;
  height: 2.45rem;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: linear-gradient(135deg, color-mix(in srgb, var(--culture-accent) 92%, #9d2f20), color-mix(in srgb, var(--culture-deep) 92%, #5b241d));
  color: #fbf2df;
  font-family: var(--font-display);
  font-size: 1rem;
  box-shadow: 0 0.9rem 1.8rem rgba(60, 40, 22, 0.12);
}

.culture-nav__copy {
  display: grid;
  gap: 0.22rem;
}

.culture-nav__label {
  font-size: 0.8rem;
  letter-spacing: 0.14rem;
}

.culture-nav__title,
.culture-card__title,
.culture-panel__bridge-title {
  margin: 0;
  font-family: var(--font-display);
  letter-spacing: 0.08rem;
}

.culture-nav__title {
  font-size: 1.18rem;
}

.culture-panel {
  min-width: 0;
}

.culture-panel__article {
  position: relative;
  padding: 1.2rem;
  border-radius: 1.45rem;
  border: 1px solid rgba(128, 93, 56, 0.14);
  background: linear-gradient(180deg, rgba(253, 249, 239, 0.92), rgba(246, 238, 220, 0.88));
  box-shadow: 0 1rem 2.2rem rgba(60, 40, 22, 0.08);
  overflow: hidden;
}

.culture-panel__article::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 14% 16%, rgba(255, 255, 255, 0.28), transparent 16%),
    linear-gradient(135deg, transparent 0 30%, color-mix(in srgb, var(--culture-accent) 10%, rgba(157, 47, 32, 0.03)) 48%, transparent 66%);
  pointer-events: none;
}

.culture-panel__header,
.culture-panel__quote,
.culture-panel__metrics,
.culture-panel__cards,
.culture-panel__bridge {
  position: relative;
  z-index: 1;
}

.culture-panel__header {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid rgba(122, 89, 54, 0.12);
}

.culture-panel__seal {
  width: 4.2rem;
  height: 4.2rem;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background:
    radial-gradient(circle at 30% 20%, rgba(255, 255, 255, 0.24), transparent 28%),
    linear-gradient(135deg, color-mix(in srgb, var(--culture-accent) 88%, #9d2f20), color-mix(in srgb, var(--culture-deep) 92%, #5b241d));
  color: #fbf2df;
  font-family: var(--font-display);
  font-size: 1.12rem;
  letter-spacing: 0.08rem;
  box-shadow: 0 1rem 2rem rgba(125, 31, 23, 0.18);
}

.culture-panel__titles {
  display: grid;
  gap: 0.4rem;
}

.culture-panel__title {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(1.8rem, 3.2vw, 2.8rem);
  letter-spacing: 0.1rem;
}

.culture-panel__note {
  line-height: 1.84;
}

.culture-panel__quote {
  margin-top: 1rem;
  padding: 1rem 1.05rem;
  border-radius: 1.25rem;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--culture-wash) 62%, rgba(255, 250, 241, 0.92)), rgba(255, 251, 243, 0.88));
  border: 1px solid color-mix(in srgb, var(--culture-accent) 18%, rgba(128, 93, 56, 0.12));
}

.culture-panel__quote-text {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(1.2rem, 2vw, 1.5rem);
  line-height: 1.72;
  letter-spacing: 0.05rem;
}

.culture-panel__quote-source {
  margin-top: 0.6rem;
  letter-spacing: 0.14rem;
}

.culture-panel__metrics {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(9rem, 1fr));
  gap: 0.8rem;
  margin-top: 1rem;
}

.culture-panel__metric {
  padding: 0.9rem 0.95rem;
  border-radius: 1.15rem;
  background: rgba(255, 251, 243, 0.68);
  border: 1px solid rgba(202, 159, 72, 0.12);
  display: grid;
  gap: 0.16rem;
}

.culture-panel__metric-label {
  font-size: 0.76rem;
  letter-spacing: 0.16rem;
}

.culture-panel__metric-value {
  font-family: var(--font-display);
  font-size: 1rem;
}

.culture-panel__cards {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.9rem;
  margin-top: 1rem;
}

.culture-card {
  padding: 1rem 1rem 1.05rem;
  border-radius: 1.2rem;
  background: rgba(255, 251, 243, 0.66);
  border: 1px solid rgba(202, 159, 72, 0.12);
  opacity: 0;
  transform: translateY(12px);
  animation: fadeSlide 0.55s ease forwards;
  animation-delay: var(--culture-card-delay, 0ms);
}

.culture-card__meta {
  font-size: 0.78rem;
  letter-spacing: 0.14rem;
}

.culture-card__title {
  margin-top: 0.35rem;
  font-size: 1.24rem;
}

.culture-card__quote {
  margin: 0.8rem 0 0;
  padding-left: 0.85rem;
  border-left: 3px solid color-mix(in srgb, var(--culture-accent) 42%, rgba(202, 159, 72, 0.18));
  font-family: var(--font-display);
  font-size: 1rem;
  line-height: 1.8;
  color: rgba(27, 21, 16, 0.92);
}

.culture-card__note {
  margin-top: 0.85rem;
  line-height: 1.84;
  color: rgba(27, 21, 16, 0.86);
}

.culture-card__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-top: 0.85rem;
}

.culture-card__tag {
  padding: 0.34rem 0.72rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--culture-wash) 55%, rgba(255, 250, 241, 0.92));
  border: 1px solid color-mix(in srgb, var(--culture-accent) 18%, rgba(202, 159, 72, 0.12));
  color: rgba(27, 21, 16, 0.78);
  font-size: 0.8rem;
}

.culture-panel__shelf {
  margin-top: 1rem;
  padding: 1rem 1.05rem 1.05rem;
  border-radius: 1.25rem;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--culture-wash) 48%, rgba(255, 250, 241, 0.92)), rgba(255, 251, 243, 0.84));
  border: 1px solid color-mix(in srgb, var(--culture-accent) 16%, rgba(202, 159, 72, 0.12));
}

.culture-panel__shelf-head {
  display: flex;
  justify-content: space-between;
  gap: 0.8rem;
  align-items: end;
  flex-wrap: wrap;
}

.culture-panel__shelf-title {
  margin: 0;
  font-family: var(--font-display);
  font-size: 1.24rem;
  letter-spacing: 0.08rem;
}

.culture-panel__shelf-note {
  margin: 0;
  color: var(--ink-soft);
  font-size: 0.88rem;
  letter-spacing: 0.06rem;
}

.culture-panel__shelf-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(14rem, 1fr));
  gap: 0.8rem;
  margin-top: 0.9rem;
  max-height: min(58rem, 72vh);
  overflow: auto;
  padding-right: 0.35rem;
  align-content: start;
}

.culture-shelf-card {
  padding: 0.9rem 0.95rem 0.95rem;
  border-radius: 1.1rem;
  background: rgba(255, 251, 243, 0.76);
  border: 1px solid rgba(202, 159, 72, 0.12);
  opacity: 0;
  transform: translateY(10px);
  animation: fadeSlide 0.48s ease forwards;
  animation-delay: var(--culture-shelf-delay, 0ms);
}

.culture-shelf-card__meta,
.culture-shelf-card__quote {
  margin: 0;
}

.culture-shelf-card__meta {
  color: var(--ink-soft);
  font-size: 0.74rem;
  letter-spacing: 0.12rem;
}

.culture-shelf-card__title {
  margin: 0.3rem 0 0;
  font-family: var(--font-display);
  font-size: 1.08rem;
  letter-spacing: 0.06rem;
}

.culture-shelf-card__quote {
  margin-top: 0.65rem;
  line-height: 1.82;
  color: rgba(27, 21, 16, 0.9);
}

.culture-shelf-card__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  margin-top: 0.7rem;
}

.culture-shelf-card__tags .culture-card__tag {
  font-size: 0.76rem;
  padding-inline: 0.62rem;
}

.culture-panel__bridge {
  margin-top: 1rem;
  padding: 1rem 1.05rem;
  border-radius: 1.25rem;
  background: linear-gradient(180deg, rgba(255, 250, 241, 0.88), rgba(248, 239, 217, 0.82));
  border: 1px solid rgba(202, 159, 72, 0.12);
}

.culture-panel__bridge-title {
  font-size: 1.18rem;
}

.culture-panel__bridge-text {
  margin-top: 0.55rem;
  line-height: 1.82;
}

.culture-panel__links {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
  margin-top: 0.95rem;
}

.culture-panel__link {
  display: inline-flex;
  align-items: center;
  padding: 0.42rem 0.8rem;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--culture-accent) 18%, rgba(202, 159, 72, 0.12));
  background: rgba(255, 251, 243, 0.86);
  color: var(--culture-deep);
  text-decoration: none;
  font-size: 0.84rem;
  transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
}

.culture-panel__link:hover {
  transform: translateY(-2px);
  border-color: color-mix(in srgb, var(--culture-accent) 34%, rgba(202, 159, 72, 0.16));
  box-shadow: 0 0.8rem 1.6rem rgba(60, 40, 22, 0.08);
}

.season-compass__head {
  position: relative;
  z-index: 1;
  margin-bottom: 1rem;
}

.season-compass__heading {
  display: flex;
  align-items: center;
  gap: 1rem;
}

.season-compass__seal {
  width: 4rem;
  height: 4rem;
  display: grid;
  place-items: center;
  border-radius: 50%;
  border: 1px solid rgba(157, 47, 32, 0.2);
  color: var(--vermillion);
  font-family: var(--font-display);
  font-size: 1.35rem;
  box-shadow: inset 0 0 0 0.28rem rgba(157, 47, 32, 0.06);
}

.season-compass__titles {
  display: grid;
  gap: 0.35rem;
}

.season-compass__label {
  margin: 0;
  color: var(--ink-soft);
  letter-spacing: 0.18rem;
}

.season-compass__title {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(1.9rem, 3.2vw, 2.9rem);
  letter-spacing: 0.1rem;
}

.season-compass__body {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(320px, 480px) minmax(0, 1fr);
  gap: 1rem;
  align-items: center;
}

.season-compass__stage,
.season-compass__detail-card,
.timing-panel,
.cast-flow-entry {
  position: relative;
  border-radius: 1.45rem;
  border: 1px solid rgba(125, 91, 55, 0.14);
  background: linear-gradient(180deg, rgba(253, 249, 239, 0.92), rgba(246, 238, 220, 0.88));
  box-shadow: 0 1rem 2.2rem rgba(60, 40, 22, 0.08);
  overflow: hidden;
}

.season-compass__stage::before,
.season-compass__detail-card::before,
.timing-panel::before,
.cast-flow-entry::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 14% 16%, rgba(255, 255, 255, 0.26), transparent 16%),
    linear-gradient(135deg, transparent 0 28%, rgba(157, 47, 32, 0.03) 46%, transparent 66%);
  pointer-events: none;
}

.season-compass__stage {
  min-height: 34rem;
  display: grid;
  place-items: center;
  padding: 1.25rem;
}

.season-compass__wheel {
  position: relative;
  width: min(100%, 28rem);
  aspect-ratio: 1;
  border-radius: 50%;
  border: 1px solid rgba(202, 159, 72, 0.28);
  background:
    radial-gradient(circle at center, rgba(255, 249, 235, 0.74), rgba(238, 223, 187, 0.22) 54%, transparent 55%),
    radial-gradient(circle, rgba(255, 255, 255, 0.26), transparent 62%);
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.18),
    0 1.2rem 2.4rem rgba(60, 40, 22, 0.08);
  animation: spinSlow 24s linear infinite;
}

.season-compass__wheel::before,
.season-compass__wheel::after {
  content: "";
  position: absolute;
  inset: 8%;
  border-radius: 50%;
}

.season-compass__wheel::before {
  border: 1px dashed rgba(202, 159, 72, 0.26);
}

.season-compass__wheel::after {
  inset: 24%;
  border: 1px solid rgba(157, 47, 32, 0.12);
}

.season-compass__center {
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.season-compass__center-seal {
  position: absolute;
  left: 50%;
  top: 50%;
  translate: -50% -50%;
  width: 5.3rem;
  height: 5.3rem;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background:
    radial-gradient(circle at 30% 20%, rgba(255, 255, 255, 0.24), transparent 28%),
    linear-gradient(135deg, rgba(157, 47, 32, 0.96), rgba(121, 26, 19, 0.96));
  color: #fbf2df;
  font-family: var(--font-display);
  font-size: 1.35rem;
  box-shadow: 0 1rem 2rem rgba(125, 31, 23, 0.16);
}

.season-compass__center-text {
  position: absolute;
  left: 50%;
  top: calc(50% + 4.1rem);
  translate: -50% 0;
  width: max-content;
  text-align: center;
  color: var(--ink-soft);
  letter-spacing: 0.22rem;
  font-size: 0.86rem;
}

.season-compass__node {
  appearance: none;
  position: absolute;
  left: 50%;
  top: 50%;
  --radius: 12rem;
  width: 6.6rem;
  padding: 0.7rem 0.55rem;
  border-radius: 1rem;
  border: 1px solid rgba(125, 91, 55, 0.14);
  background: rgba(255, 251, 243, 0.84);
  box-shadow: 0 1rem 2rem rgba(60, 40, 22, 0.08);
  display: grid;
  gap: 0.5rem;
  justify-items: center;
  cursor: pointer;
  color: inherit;
  transform: translate(-50%, -50%) rotate(var(--angle)) translateY(calc(var(--radius) * -1)) rotate(calc(var(--angle) * -1));
  opacity: 0;
  animation: compassNodeIn 0.6s ease forwards;
  animation-delay: var(--compass-delay, 0ms);
  transition: transform 0.35s ease, box-shadow 0.35s ease, border-color 0.35s ease;
}

.season-compass__node:hover,
.season-compass__node.is-active {
  border-color: rgba(202, 159, 72, 0.42);
  box-shadow: 0 1.2rem 2.2rem rgba(60, 40, 22, 0.1), 0 0 0 1px rgba(202, 159, 72, 0.14);
}

.season-compass__node.is-active {
  transform: translate(-50%, -50%) rotate(var(--angle)) translateY(calc(var(--radius) * -1)) rotate(calc(var(--angle) * -1)) scale(1.04);
}

.season-compass__node-name {
  font-family: var(--font-display);
  font-size: 1.12rem;
}

.season-compass__node-figure .figure {
  min-width: 4.7rem;
  gap: 0.28rem;
}

.season-compass__node-figure .figure__line {
  height: 0.38rem;
}

.season-compass__detail-card {
  padding: 1.2rem;
  display: grid;
  gap: 1rem;
}

.season-compass__detail-head {
  display: flex;
  gap: 1rem;
  align-items: center;
}

.season-compass__detail-seal {
  width: 4rem;
  height: 4rem;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: rgba(202, 159, 72, 0.12);
  color: var(--gold);
  font-family: var(--font-display);
  font-size: 1.5rem;
}

.season-compass__detail-titles {
  display: grid;
  gap: 0.3rem;
}

.season-compass__detail-title {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(1.6rem, 3vw, 2.4rem);
}

.season-compass__detail-meta,
.season-compass__detail-emblem {
  margin: 0;
  color: var(--ink-soft);
  letter-spacing: 0.16rem;
}

.season-compass__detail-figure .figure {
  min-width: 11rem;
  gap: 0.6rem;
}

.season-compass__detail-text {
  margin: 0;
  line-height: 1.92;
  color: rgba(27, 21, 16, 0.88);
}

.heluo-atlas {
  --heluo-accent: #9c6e3a;
  --heluo-deep: #5d3e20;
  --heluo-wash: rgba(156, 110, 58, 0.14);
  position: relative;
  isolation: isolate;
  overflow: hidden;
}

.heluo-atlas__mist {
  position: absolute;
  width: 22rem;
  height: 22rem;
  border-radius: 50%;
  filter: blur(18px);
  opacity: 0.34;
  pointer-events: none;
}

.heluo-atlas__mist--a {
  top: -7rem;
  left: -4.6rem;
  background: radial-gradient(circle, color-mix(in srgb, var(--heluo-accent) 28%, rgba(255, 252, 246, 0.2)), transparent 72%);
}

.heluo-atlas__mist--b {
  right: -6rem;
  bottom: -8rem;
  background: radial-gradient(circle, color-mix(in srgb, var(--heluo-accent) 16%, rgba(112, 139, 91, 0.16)), transparent 72%);
}

.heluo-atlas__head {
  position: relative;
  z-index: 1;
  margin-bottom: 1rem;
}

.heluo-atlas__heading {
  display: flex;
  align-items: center;
  gap: 1rem;
}

.heluo-atlas__seal {
  width: 4rem;
  height: 4rem;
  display: grid;
  place-items: center;
  border-radius: 1.18rem;
  border: 1px solid color-mix(in srgb, var(--heluo-accent) 26%, rgba(157, 47, 32, 0.12));
  color: var(--heluo-deep);
  font-family: var(--font-display);
  font-size: 1.36rem;
  background:
    radial-gradient(circle at 28% 26%, rgba(255, 255, 255, 0.42), transparent 25%),
    linear-gradient(180deg, rgba(255, 250, 241, 0.96), rgba(245, 234, 210, 0.9));
  box-shadow:
    inset 0 0 0 0.32rem color-mix(in srgb, var(--heluo-wash) 58%, rgba(255, 255, 255, 0)),
    0 0.9rem 1.8rem rgba(60, 40, 22, 0.08);
}

.heluo-atlas__titles {
  display: grid;
  gap: 0.35rem;
}

.heluo-atlas__label,
.heluo-atlas__note,
.heluo-atlas__aside-label,
.heluo-atlas__aside-text,
.heluo-nav__note,
.heluo-panel__hero-label,
.heluo-panel__hero-note,
.heluo-panel__orientation,
.heluo-panel__summary-title,
.heluo-panel__summary-text,
.heluo-panel__metric-label,
.heluo-grid__note,
.heluo-grid__center-note,
.heluo-panel__block-text,
.heluo-panel__list {
  margin: 0;
  color: var(--ink-soft);
}

.heluo-atlas__label {
  letter-spacing: 0.18rem;
}

.heluo-atlas__title {
  margin: 0;
  font-size: clamp(1.95rem, 3.3vw, 3rem);
  letter-spacing: 0.08rem;
}

.heluo-atlas__note {
  max-width: 48rem;
  line-height: 1.82;
}

.heluo-atlas__body {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(15rem, 16.5rem) minmax(0, 1fr);
  gap: 1.1rem;
  align-items: start;
}

.heluo-atlas__sidebar,
.heluo-panel {
  position: relative;
  border-radius: 1.45rem;
  border: 1px solid rgba(125, 91, 55, 0.14);
  background: linear-gradient(180deg, rgba(253, 249, 239, 0.92), rgba(246, 238, 220, 0.88));
  box-shadow: 0 1rem 2.2rem rgba(60, 40, 22, 0.08);
  overflow: hidden;
}

.heluo-atlas__sidebar::before,
.heluo-panel::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 14% 16%, rgba(255, 255, 255, 0.26), transparent 16%),
    linear-gradient(135deg, transparent 0 28%, color-mix(in srgb, var(--heluo-accent) 10%, transparent) 46%, transparent 66%);
  pointer-events: none;
}

.heluo-atlas__sidebar {
  padding: 1rem;
  display: grid;
  gap: 1rem;
}

.heluo-nav {
  display: grid;
  gap: 0.8rem;
}

.heluo-nav__button {
  appearance: none;
  width: 100%;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 0.8rem;
  align-items: center;
  padding: 0.95rem 1rem;
  border-radius: 1.15rem;
  border: 1px solid rgba(128, 93, 56, 0.14);
  background: linear-gradient(180deg, rgba(255, 250, 241, 0.92), rgba(248, 239, 222, 0.8));
  box-shadow: 0 0.8rem 1.6rem rgba(60, 40, 22, 0.06);
  color: inherit;
  text-align: left;
  cursor: pointer;
  transition: transform 0.3s ease, border-color 0.3s ease, box-shadow 0.3s ease, background 0.3s ease;
}

.heluo-nav__button:hover,
.heluo-nav__button.is-active {
  transform: translateY(-2px);
  border-color: color-mix(in srgb, var(--heluo-accent) 42%, rgba(128, 93, 56, 0.18));
  box-shadow: 0 1rem 2rem rgba(60, 40, 22, 0.08), 0 0 0 1px color-mix(in srgb, var(--heluo-accent) 16%, transparent);
}

.heluo-nav__button.is-active {
  background:
    radial-gradient(circle at 18% 18%, rgba(255, 255, 255, 0.24), transparent 24%),
    linear-gradient(180deg, color-mix(in srgb, var(--heluo-wash) 44%, rgba(255, 251, 243, 0.92)), rgba(255, 248, 236, 0.94));
}

.heluo-nav__seal {
  width: 2.4rem;
  height: 2.4rem;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: color-mix(in srgb, var(--heluo-accent) 84%, #5b3a26);
  color: #fbf2df;
  font-family: var(--font-display);
  font-size: 1rem;
}

.heluo-nav__copy {
  display: grid;
  gap: 0.2rem;
}

.heluo-nav__title {
  font-family: var(--font-display);
  font-size: 1rem;
}

.heluo-nav__note,
.heluo-atlas__aside-label {
  letter-spacing: 0.14rem;
  font-size: 0.78rem;
}

.heluo-atlas__aside-copy {
  padding-top: 0.9rem;
  border-top: 1px solid rgba(128, 93, 56, 0.12);
  display: grid;
  gap: 0.4rem;
}

.heluo-atlas__aside-text {
  line-height: 1.76;
}

.heluo-panel {
  padding: 1.08rem;
  display: grid;
  gap: 1rem;
}

.heluo-panel__hero,
.heluo-panel__main,
.heluo-panel__blocks {
  position: relative;
  z-index: 1;
}

.heluo-panel__hero {
  display: flex;
  gap: 1rem;
  align-items: center;
}

.heluo-panel__seal {
  width: 4rem;
  height: 4rem;
  display: grid;
  place-items: center;
  border-radius: 1.15rem;
  background: linear-gradient(135deg, color-mix(in srgb, var(--heluo-accent) 88%, #7b271d), color-mix(in srgb, var(--heluo-deep) 92%, #5b241d));
  color: #fbf2df;
  font-family: var(--font-display);
  font-size: 1.35rem;
  box-shadow: 0 0.9rem 1.8rem rgba(60, 40, 22, 0.12);
}

.heluo-panel__hero-copy {
  display: grid;
  gap: 0.28rem;
}

.heluo-panel__hero-label {
  letter-spacing: 0.14rem;
  font-size: 0.82rem;
}

.heluo-panel__hero-title,
.heluo-panel__block-title,
.heluo-grid__center-title {
  margin: 0;
  font-family: var(--font-display);
  letter-spacing: 0.08rem;
}

.heluo-panel__hero-title {
  font-size: clamp(1.8rem, 3vw, 2.6rem);
}

.heluo-panel__hero-note {
  line-height: 1.78;
}

.heluo-panel__main {
  display: grid;
  grid-template-columns: minmax(19rem, 23rem) minmax(0, 1fr);
  gap: 0.95rem;
  align-items: start;
}

.heluo-panel__diagram,
.heluo-panel__summary,
.heluo-panel__metric,
.heluo-panel__block {
  padding: 1rem 1.05rem;
  border-radius: 1.2rem;
  border: 1px solid rgba(128, 93, 56, 0.12);
  background: rgba(255, 251, 243, 0.74);
}

.heluo-panel__diagram {
  display: grid;
  gap: 0.75rem;
}

.heluo-panel__orientation {
  line-height: 1.72;
  font-size: 0.86rem;
}

.heluo-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  grid-template-rows: repeat(3, minmax(5.8rem, auto));
  gap: 0.72rem;
}

.heluo-grid__cell {
  position: relative;
  border-radius: 1rem;
  border: 1px solid rgba(128, 93, 56, 0.12);
  background:
    radial-gradient(circle at 24% 18%, rgba(255, 255, 255, 0.24), transparent 24%),
    linear-gradient(180deg, rgba(255, 252, 246, 0.98), rgba(245, 235, 214, 0.88));
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.52);
  display: grid;
  gap: 0.25rem;
  justify-items: center;
  align-content: center;
  padding: 0.85rem 0.7rem;
  text-align: center;
}

.heluo-grid__cell.is-emphasis,
.heluo-grid__cell--center {
  background:
    radial-gradient(circle at 24% 18%, rgba(255, 255, 255, 0.3), transparent 24%),
    linear-gradient(180deg, color-mix(in srgb, var(--heluo-wash) 68%, rgba(255, 252, 246, 0.98)), rgba(245, 235, 214, 0.9));
}

.heluo-grid__value {
  font-family: var(--font-display);
  font-size: 1.42rem;
  color: rgba(39, 27, 15, 0.92);
}

.heluo-grid__label {
  font-size: 0.96rem;
}

.heluo-grid__note,
.heluo-grid__center-note {
  font-size: 0.8rem;
  line-height: 1.56;
}

.heluo-grid__figure .figure {
  min-width: 5.2rem;
  gap: 0.22rem;
}

.heluo-grid__figure .figure__line {
  height: 0.3rem;
}

.heluo-grid__figure .figure__stroke {
  height: 0.3rem;
}

.heluo-panel__copy {
  display: grid;
  gap: 0.8rem;
}

.heluo-panel__summary {
  display: grid;
  gap: 0.38rem;
}

.heluo-panel__summary-title {
  letter-spacing: 0.14rem;
  font-size: 0.82rem;
}

.heluo-panel__summary-text,
.heluo-panel__block-text {
  line-height: 1.84;
  color: rgba(27, 21, 16, 0.84);
}

.heluo-panel__metrics {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.75rem;
}

.heluo-panel__metric {
  display: grid;
  gap: 0.16rem;
}

.heluo-panel__metric-label {
  font-size: 0.78rem;
  letter-spacing: 0.14rem;
}

.heluo-panel__metric-value {
  font-family: var(--font-display);
  font-size: 0.98rem;
}

.heluo-panel__blocks {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.8rem;
}

.heluo-panel__block {
  display: grid;
  gap: 0.6rem;
}

.heluo-panel__block-title {
  font-size: 1.16rem;
}

.heluo-grid__center-title {
  font-size: 1.1rem;
}

.heluo-panel__list {
  padding-left: 1.15rem;
  line-height: 1.82;
}

.heluo-panel__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.heluo-panel__tag {
  padding: 0.38rem 0.7rem;
  border-radius: 999px;
  border: 1px solid rgba(128, 93, 56, 0.12);
  background: color-mix(in srgb, var(--heluo-wash) 52%, rgba(255, 250, 241, 0.92));
  color: rgba(27, 21, 16, 0.82);
  font-size: 0.82rem;
}

@media (max-width: 1080px) {
  .heluo-atlas__body,
  .heluo-panel__main,
  .heluo-panel__blocks {
    grid-template-columns: 1fr;
  }

  .heluo-atlas__sidebar {
    padding: 0.95rem;
  }
}

@media (max-width: 820px) {
  .heluo-atlas__heading,
  .heluo-panel__hero {
    align-items: start;
  }

  .heluo-nav {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .heluo-panel__metrics {
    grid-template-columns: 1fr;
  }

  .heluo-grid {
    grid-template-rows: repeat(3, minmax(5.15rem, auto));
  }
}

@media (max-width: 560px) {
  .heluo-nav {
    grid-template-columns: 1fr;
  }

  .heluo-grid {
    gap: 0.55rem;
  }

  .heluo-grid__cell {
    padding: 0.72rem 0.5rem;
  }

  .heluo-grid__value {
    font-size: 1.22rem;
  }
}

.mingli-hall {
  --mingli-accent: #936238;
  --mingli-deep: #56351b;
  --mingli-wash: rgba(147, 98, 56, 0.14);
  position: relative;
  isolation: isolate;
  overflow: hidden;
}

.mingli-hall__mist {
  position: absolute;
  width: 22rem;
  height: 22rem;
  border-radius: 50%;
  filter: blur(20px);
  opacity: 0.34;
  pointer-events: none;
}

.mingli-hall__mist--a {
  left: -6rem;
  top: -7rem;
  background: radial-gradient(circle, color-mix(in srgb, var(--mingli-accent) 24%, rgba(255, 252, 246, 0.24)), transparent 72%);
}

.mingli-hall__mist--b {
  right: -6rem;
  bottom: -8rem;
  background: radial-gradient(circle, color-mix(in srgb, var(--mingli-accent) 20%, rgba(202, 159, 72, 0.18)), transparent 72%);
}

.mingli-hall__head {
  position: relative;
  z-index: 1;
  margin-bottom: 1rem;
}

.mingli-hall__heading {
  display: flex;
  align-items: center;
  gap: 1rem;
}

.mingli-hall__seal {
  width: 4rem;
  height: 4rem;
  display: grid;
  place-items: center;
  border-radius: 1.2rem;
  border: 1px solid color-mix(in srgb, var(--mingli-accent) 26%, rgba(157, 47, 32, 0.12));
  color: var(--mingli-deep);
  font-family: var(--font-display);
  font-size: 1.36rem;
  background:
    radial-gradient(circle at 28% 26%, rgba(255, 255, 255, 0.42), transparent 25%),
    linear-gradient(180deg, rgba(255, 250, 241, 0.96), rgba(245, 234, 210, 0.9));
  box-shadow:
    inset 0 0 0 0.32rem color-mix(in srgb, var(--mingli-wash) 58%, rgba(255, 255, 255, 0)),
    0 0.9rem 1.8rem rgba(60, 40, 22, 0.08);
}

.mingli-hall__titles {
  display: grid;
  gap: 0.35rem;
}

.mingli-hall__label,
.mingli-hall__note,
.mingli-form__label,
.mingli-form__caption,
.mingli-form__hint,
.mingli-side-card__note,
.mingli-term__note,
.mingli-report__label,
.mingli-report__note,
.mingli-metric__label,
.mingli-metric__note,
.mingli-element__detail,
.mingli-pillar__label,
.mingli-pillar__line--soft,
.mingli-report__placeholder-note {
  margin: 0;
  color: var(--ink-soft);
}

.mingli-hall__label,
.mingli-form__caption,
.mingli-report__label,
.mingli-metric__label,
.mingli-pillar__label {
  letter-spacing: 0.16rem;
}

.mingli-hall__title {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(1.95rem, 3.3vw, 3rem);
  letter-spacing: 0.08rem;
}

.mingli-hall__note {
  max-width: 48rem;
  line-height: 1.82;
}

.mingli-hall__body {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(17rem, 19rem) minmax(0, 1fr);
  gap: 1.2rem;
  align-items: start;
}

.mingli-hall__body.is-locked {
  grid-template-columns: minmax(0, 1fr);
}

.mingli-hall__sidebar,
.mingli-panel,
.mingli-form,
.mingli-side-card {
  position: relative;
  border-radius: 1.45rem;
  border: 1px solid rgba(125, 91, 55, 0.14);
  background: linear-gradient(180deg, rgba(253, 249, 239, 0.92), rgba(246, 238, 220, 0.88));
  box-shadow: 0 1rem 2.2rem rgba(60, 40, 22, 0.08);
  overflow: hidden;
}

.mingli-hall__sidebar::before,
.mingli-panel::before,
.mingli-form::before,
.mingli-side-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 14% 16%, rgba(255, 255, 255, 0.26), transparent 16%),
    linear-gradient(135deg, transparent 0 28%, color-mix(in srgb, var(--mingli-accent) 10%, transparent) 46%, transparent 66%);
  pointer-events: none;
}

.mingli-hall__sidebar {
  padding: 1rem;
  display: grid;
  gap: 1rem;
  position: sticky;
  top: 6.6rem;
}

.mingli-lock {
  position: relative;
  z-index: 1;
  min-height: 30rem;
  padding: 2.2rem 2rem;
  display: grid;
  align-content: center;
  justify-items: center;
  gap: 0.95rem;
  text-align: center;
  border-radius: 1.45rem;
  border: 1px solid rgba(125, 91, 55, 0.14);
  background: linear-gradient(180deg, rgba(253, 249, 239, 0.94), rgba(246, 238, 220, 0.9));
  box-shadow: 0 1rem 2.2rem rgba(60, 40, 22, 0.08);
  overflow: hidden;
}

.mingli-lock::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 14% 16%, rgba(255, 255, 255, 0.26), transparent 16%),
    linear-gradient(135deg, transparent 0 28%, color-mix(in srgb, var(--mingli-accent) 10%, transparent) 46%, transparent 66%);
  pointer-events: none;
}

.mingli-lock__seal,
.mingli-lock__title,
.mingli-lock__note,
.mingli-lock__hint,
.mingli-lock__input,
.mingli-lock__action {
  position: relative;
  z-index: 1;
}

.mingli-lock__seal {
  width: 4.4rem;
  height: 4.4rem;
  display: grid;
  place-items: center;
  border-radius: 50%;
  border: 1px solid rgba(157, 47, 32, 0.18);
  color: var(--vermillion);
  font-family: var(--font-display);
  font-size: 1.5rem;
  box-shadow: inset 0 0 0 0.34rem rgba(157, 47, 32, 0.06);
}

.mingli-lock__title {
  margin: 0;
  font-family: var(--font-display);
  font-size: 1.5rem;
  letter-spacing: 0.08rem;
}

.mingli-lock__note,
.mingli-lock__hint {
  margin: 0;
  max-width: 32rem;
  line-height: 1.8;
}

.mingli-lock__input {
  width: min(22rem, 100%);
  min-height: 3.3rem;
  padding: 0.9rem 1rem;
  border-radius: 1rem;
  border: 1px solid rgba(128, 93, 56, 0.14);
  background: rgba(255, 251, 243, 0.88);
  color: var(--ink);
  outline: none;
  transition: border-color 0.25s ease, box-shadow 0.25s ease;
}

.mingli-lock__input:focus {
  border-color: color-mix(in srgb, var(--mingli-accent) 38%, rgba(202, 159, 72, 0.16));
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--mingli-wash) 50%, rgba(255, 255, 255, 0));
}

.mingli-lock__action {
  width: min(14rem, 100%);
}

.mingli-lock__hint {
  color: var(--ink-soft);
}

.mingli-lock__hint.is-error {
  color: rgba(148, 52, 34, 0.94);
}

.mingli-form,
.mingli-side-card,
.mingli-report {
  position: relative;
  z-index: 1;
}

.mingli-form,
.mingli-side-card {
  padding: 1rem;
  display: grid;
  gap: 0.8rem;
}

.mingli-form__field {
  display: grid;
  gap: 0.45rem;
}

.mingli-form__input {
  width: 100%;
  min-height: 3.25rem;
  padding: 0.9rem 1rem;
  border-radius: 1rem;
  border: 1px solid rgba(128, 93, 56, 0.14);
  background: rgba(255, 251, 243, 0.86);
  color: var(--ink);
  outline: none;
  transition: border-color 0.25s ease, box-shadow 0.25s ease;
}

.mingli-form__input:focus {
  border-color: color-mix(in srgb, var(--mingli-accent) 38%, rgba(202, 159, 72, 0.16));
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--mingli-wash) 50%, rgba(255, 255, 255, 0));
}

.mingli-form__select {
  appearance: none;
  background:
    linear-gradient(45deg, transparent 50%, rgba(128, 93, 56, 0.72) 50%) calc(100% - 1.2rem) calc(50% - 0.12rem) / 0.5rem 0.5rem no-repeat,
    linear-gradient(135deg, rgba(128, 93, 56, 0.72) 50%, transparent 50%) calc(100% - 0.85rem) calc(50% - 0.12rem) / 0.5rem 0.5rem no-repeat,
    rgba(255, 251, 243, 0.86);
  padding-right: 2.4rem;
}

.mingli-form__hint {
  line-height: 1.72;
}

.mingli-form__action {
  width: 100%;
}

.mingli-ai-side {
  display: grid;
  gap: 0.8rem;
}

.mingli-ai-side__hint {
  margin: 0;
}

.mingli-ai-side__status {
  margin: 0;
  min-height: 1.8rem;
  line-height: 1.72;
  color: var(--ink-soft);
}

.mingli-ai-side__status.is-ready {
  color: rgba(83, 101, 43, 0.96);
}

.mingli-ai-side__status.is-error {
  color: rgba(148, 52, 34, 0.94);
}

.mingli-ai-side__actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.65rem;
}

.mingli-ai-side__actions .panel__button:nth-child(3),
.mingli-ai-side__actions .panel__button:nth-child(4) {
  grid-column: 1 / -1;
}

.mingli-side-card__title,
.mingli-card__title,
.mingli-report__title,
.mingli-report__placeholder-title {
  margin: 0;
  font-family: var(--font-display);
  letter-spacing: 0.08rem;
}

.mingli-side-card__title {
  font-size: 1.18rem;
}

.mingli-example-list,
.mingli-term-grid {
  display: grid;
  gap: 0.7rem;
}

.mingli-example {
  appearance: none;
  width: 100%;
  padding: 0.9rem 0.95rem;
  border-radius: 1.1rem;
  border: 1px solid rgba(128, 93, 56, 0.14);
  background: rgba(255, 251, 243, 0.78);
  color: inherit;
  text-align: left;
  cursor: pointer;
  display: grid;
  gap: 0.25rem;
  opacity: 0;
  transform: translateY(10px);
  animation: fadeSlide 0.5s ease forwards;
  animation-delay: var(--mingli-delay, 0ms);
  transition: transform 0.25s ease, border-color 0.25s ease, box-shadow 0.25s ease;
}

.mingli-example:hover {
  transform: translateY(-2px);
  border-color: color-mix(in srgb, var(--mingli-accent) 34%, rgba(202, 159, 72, 0.16));
  box-shadow: 0 0.9rem 1.6rem rgba(60, 40, 22, 0.08);
}

.mingli-example__label {
  color: var(--ink-soft);
  font-size: 0.82rem;
  letter-spacing: 0.12rem;
}

.mingli-example__value {
  font-family: var(--font-display);
  font-size: 1.02rem;
}

.mingli-term-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.mingli-term {
  appearance: none;
  width: 100%;
  padding: 0.85rem 0.9rem;
  border-radius: 1rem;
  background: rgba(255, 251, 243, 0.74);
  border: 1px solid rgba(202, 159, 72, 0.12);
  display: grid;
  gap: 0.35rem;
  text-align: left;
  color: inherit;
  cursor: pointer;
  transition: transform 0.25s ease, border-color 0.25s ease, box-shadow 0.25s ease;
}

.mingli-term:hover,
.mingli-term.is-active {
  transform: translateY(-2px);
  border-color: color-mix(in srgb, var(--mingli-accent) 36%, rgba(202, 159, 72, 0.16));
  box-shadow: 0 0.85rem 1.5rem rgba(60, 40, 22, 0.08);
}

.mingli-term__title {
  margin: 0;
  font-family: var(--font-display);
  font-size: 1rem;
}

.mingli-term__note {
  line-height: 1.7;
}

.mingli-term__action,
.mingli-term-detail__label,
.mingli-term-detail__source {
  margin: 0;
  color: var(--ink-soft);
}

.mingli-term__action {
  font-size: 0.82rem;
  letter-spacing: 0.08rem;
}

.mingli-term-detail {
  display: grid;
  gap: 0.85rem;
  padding: 0.9rem 0.95rem;
  border-radius: 1rem;
  background: rgba(255, 251, 243, 0.78);
  border: 1px solid rgba(202, 159, 72, 0.12);
}

.mingli-term-detail__head,
.mingli-term-detail__section,
.mingli-term-detail__body,
.mingli-term-detail__list,
.mingli-term-detail__item {
  display: grid;
  gap: 0.35rem;
}

.mingli-term-detail__title {
  margin: 0;
  font-family: var(--font-display);
  font-size: 1.12rem;
}

.mingli-term-detail__note,
.mingli-term-detail__text {
  margin: 0;
  line-height: 1.86;
  color: rgba(27, 21, 16, 0.88);
}

.mingli-term-detail__item {
  padding: 0.82rem 0.88rem;
  border-radius: 0.95rem;
  border: 1px solid rgba(128, 93, 56, 0.1);
  background: rgba(255, 252, 246, 0.78);
}

.mingli-term-detail__item-title {
  margin: 0;
  font-family: var(--font-display);
  font-size: 1rem;
}

.mingli-term-detail__example {
  margin: 0;
  line-height: 1.8;
  color: var(--ink-soft);
  text-indent: 2em;
}

.mingli-term-detail__text,
.mingli-card__text,
.mingli-branch-list__item,
.mingli-source__text {
  text-indent: 2em;
}

.mingli-panel {
  padding: 1.08rem;
  min-height: 42rem;
}

.mingli-report {
  display: grid;
  gap: 1rem;
  align-content: start;
}

.mingli-report--placeholder {
  min-height: 20rem;
  place-content: center;
  text-align: center;
  padding: 2rem 1.5rem;
}

.mingli-report__placeholder-title {
  font-size: clamp(1.9rem, 3vw, 2.5rem);
}

.mingli-report__placeholder-note {
  margin-top: 0.7rem;
  line-height: 1.82;
}

.mingli-report__hero,
.mingli-report__metrics,
.mingli-report__main,
.mingli-report__grid {
  position: relative;
  z-index: 1;
}

.mingli-report__hero {
  display: flex;
  gap: 1rem;
  align-items: center;
  padding: 1rem 1.05rem;
  border-radius: 1.25rem;
  background:
    radial-gradient(circle at 18% 16%, rgba(255, 255, 255, 0.2), transparent 22%),
    linear-gradient(180deg, color-mix(in srgb, var(--mingli-wash) 54%, rgba(255, 250, 241, 0.94)), rgba(255, 251, 243, 0.82));
  border: 1px solid rgba(128, 93, 56, 0.12);
}

.mingli-report__seal {
  width: 4rem;
  height: 4rem;
  display: grid;
  place-items: center;
  border-radius: 1.15rem;
  background: linear-gradient(135deg, color-mix(in srgb, var(--mingli-accent) 88%, #7b271d), color-mix(in srgb, var(--mingli-deep) 92%, #5b241d));
  color: #fbf2df;
  font-family: var(--font-display);
  font-size: 1.35rem;
  box-shadow: 0 0.9rem 1.8rem rgba(60, 40, 22, 0.12);
}

.mingli-report__titles {
  display: grid;
  gap: 0.3rem;
}

.mingli-report__title {
  font-size: clamp(1.8rem, 3vw, 2.6rem);
}

.mingli-report__note {
  line-height: 1.78;
}

.mingli-report__metrics {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(10rem, 1fr));
  gap: 0.8rem;
}

.mingli-metric,
.mingli-card {
  padding: 0.95rem 1rem;
  border-radius: 1.15rem;
  border: 1px solid rgba(128, 93, 56, 0.12);
  background:
    radial-gradient(circle at 16% 14%, rgba(255, 255, 255, 0.24), transparent 22%),
    linear-gradient(180deg, rgba(255, 251, 242, 0.96), rgba(245, 233, 210, 0.9));
}

.mingli-card--summary {
  background:
    radial-gradient(circle at 16% 14%, rgba(255, 255, 255, 0.24), transparent 22%),
    linear-gradient(180deg, color-mix(in srgb, var(--mingli-wash) 44%, rgba(255, 250, 241, 0.96)), rgba(255, 251, 243, 0.84));
}

.mingli-score {
  display: grid;
  gap: 0.95rem;
  padding: 1rem 1.05rem;
  border-radius: 1.25rem;
  border: 1px solid rgba(128, 93, 56, 0.12);
  background:
    radial-gradient(circle at 14% 18%, rgba(255, 255, 255, 0.24), transparent 24%),
    linear-gradient(180deg, rgba(255, 252, 246, 0.96), rgba(244, 233, 212, 0.9));
}

.mingli-score__head {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 1rem;
  align-items: center;
}

.mingli-score__value-block {
  display: flex;
  align-items: baseline;
  gap: 0.25rem;
  padding: 0.9rem 1rem;
  border-radius: 1.1rem;
  background: linear-gradient(180deg, rgba(110, 42, 24, 0.92), rgba(146, 60, 37, 0.92));
  color: rgba(255, 248, 238, 0.96);
  box-shadow: 0 0.85rem 1.7rem rgba(112, 62, 33, 0.16);
}

.mingli-score__value {
  font-family: var(--font-display);
  font-size: clamp(2rem, 3vw, 2.7rem);
  line-height: 1;
}

.mingli-score__unit,
.mingli-score__grade,
.mingli-score__summary,
.mingli-score__note,
.mingli-score__item-label,
.mingli-score__item-note {
  margin: 0;
}

.mingli-score__unit {
  font-size: 0.96rem;
  color: rgba(255, 244, 230, 0.84);
}

.mingli-score__title {
  margin: 0;
  font-family: var(--font-display);
  font-size: 1.14rem;
}

.mingli-score__grade {
  color: var(--ink-soft);
  letter-spacing: 0.08rem;
}

.mingli-score__summary {
  line-height: 1.82;
  color: rgba(27, 21, 16, 0.92);
}

.mingli-score__note {
  color: var(--ink-soft);
  line-height: 1.7;
}

.mingli-score__breakdown {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.85rem;
}

.mingli-score__item {
  display: grid;
  gap: 0.45rem;
  padding: 0.88rem 0.95rem;
  border-radius: 1rem;
  border: 1px solid rgba(128, 93, 56, 0.1);
  background: rgba(255, 251, 243, 0.72);
}

.mingli-score__item-top {
  display: flex;
  justify-content: space-between;
  gap: 0.8rem;
  align-items: baseline;
}

.mingli-score__item-label {
  color: var(--ink-soft);
  letter-spacing: 0.08rem;
}

.mingli-score__item-value {
  font-family: var(--font-display);
  font-size: 1rem;
}

.mingli-score__track {
  position: relative;
  overflow: hidden;
  height: 0.44rem;
  border-radius: 999px;
  background: rgba(143, 117, 81, 0.14);
}

.mingli-score__fill {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, rgba(171, 115, 43, 0.92), rgba(214, 175, 94, 0.96));
}

.mingli-score__item-note {
  line-height: 1.76;
  color: rgba(27, 21, 16, 0.88);
  text-indent: 2em;
}

.mingli-metric {
  display: grid;
  gap: 0.2rem;
}

.mingli-metric__value {
  font-family: var(--font-display);
  font-size: 1.14rem;
}

.mingli-metric__note {
  line-height: 1.68;
}

.mingli-report__main {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr);
  gap: 0.9rem;
  align-items: start;
}

.mingli-pillars {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.8rem;
  margin-top: 0.85rem;
}

.mingli-pillar {
  padding: 0.9rem 0.95rem;
  border-radius: 1rem;
  background: linear-gradient(180deg, rgba(255, 252, 246, 0.96), rgba(245, 235, 214, 0.88));
  border: 1px solid rgba(128, 93, 56, 0.1);
  display: grid;
  gap: 0.28rem;
}

.mingli-pillar__value {
  margin: 0;
  font-family: var(--font-display);
  font-size: 1.46rem;
  letter-spacing: 0.08rem;
}

.mingli-pillar__line {
  margin: 0;
  line-height: 1.72;
}

.mingli-elements {
  display: grid;
  gap: 0.8rem;
  margin-top: 0.85rem;
}

.mingli-element {
  display: grid;
  gap: 0.4rem;
}

.mingli-element__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.8rem;
}

.mingli-element__label {
  font-family: var(--font-display);
  font-size: 1.02rem;
}

.mingli-element__value {
  color: var(--ink-soft);
  font-size: 0.84rem;
}

.mingli-element__track {
  height: 0.62rem;
  border-radius: 999px;
  background: rgba(202, 159, 72, 0.14);
  overflow: hidden;
}

.mingli-element__fill {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, color-mix(in srgb, var(--mingli-accent) 82%, #cfa252), color-mix(in srgb, var(--mingli-deep) 78%, #8f6238));
}

.mingli-element__detail {
  line-height: 1.64;
}

.mingli-report__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.9rem;
  align-items: start;
}

.mingli-card {
  display: grid;
  gap: 0.6rem;
  align-content: start;
}

.mingli-card__title {
  font-size: 1.2rem;
}

.mingli-card__text {
  margin: 0;
  line-height: 1.86;
  color: rgba(27, 21, 16, 0.88);
}

.mingli-card__text--note {
  color: var(--ink-soft);
  font-size: 0.92rem;
}

.mingli-facts {
  display: grid;
  gap: 0;
  border-top: 1px solid rgba(128, 93, 56, 0.08);
}

.mingli-fact {
  margin: 0;
  display: grid;
  grid-template-columns: 4.8rem minmax(0, 1fr);
  gap: 0.8rem;
  align-items: start;
  line-height: 1.72;
  padding: 0.52rem 0;
  border-bottom: 1px solid rgba(128, 93, 56, 0.08);
}

.mingli-fact__label {
  color: var(--ink-soft);
  letter-spacing: 0.08rem;
}

.mingli-fact__value {
  color: rgba(27, 21, 16, 0.88);
}

.mingli-chip-list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
}

.mingli-chip {
  display: inline-flex;
  align-items: center;
  padding: 0.38rem 0.72rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--mingli-wash) 58%, rgba(255, 250, 241, 0.92));
  border: 1px solid rgba(128, 93, 56, 0.12);
  color: rgba(27, 21, 16, 0.82);
  font-size: 0.82rem;
}

.mingli-branch-list,
.mingli-source__body {
  display: grid;
  gap: 0.6rem;
}

.mingli-branch-list__item,
.mingli-source__meta,
.mingli-source__text {
  margin: 0;
}

.mingli-branch-list__item {
  line-height: 1.82;
  color: rgba(27, 21, 16, 0.88);
}

.mingli-classics {
  display: grid;
  gap: 0.85rem;
  padding: 0.95rem 1rem;
  border-radius: 1.15rem;
  border: 1px solid rgba(128, 93, 56, 0.12);
  background:
    radial-gradient(circle at 16% 14%, rgba(255, 255, 255, 0.2), transparent 22%),
    rgba(255, 251, 243, 0.78);
}

.mingli-ai {
  display: grid;
  gap: 0.85rem;
  padding: 0.95rem 1rem;
  border-radius: 1.15rem;
  border: 1px solid rgba(128, 93, 56, 0.12);
  background:
    radial-gradient(circle at 16% 14%, rgba(255, 255, 255, 0.2), transparent 22%),
    rgba(255, 250, 242, 0.82);
}

.mingli-ai__body {
  display: grid;
  gap: 0.75rem;
  margin-top: 0.75rem;
}

.mingli-ai__card {
  gap: 0.7rem;
}

.mingli-premium {
  display: grid;
  gap: 0.9rem;
}

.mingli-premium__cover {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 1rem;
  align-items: start;
  padding: 1rem 1.05rem;
  border-radius: 1.1rem;
  border: 1px solid rgba(128, 93, 56, 0.1);
  background:
    radial-gradient(circle at 15% 14%, rgba(255, 255, 255, 0.22), transparent 24%),
    linear-gradient(180deg, rgba(253, 248, 238, 0.98), rgba(242, 229, 205, 0.9));
}

.mingli-premium__cover-meta,
.mingli-premium__insight,
.mingli-premium__sections {
  display: grid;
  gap: 0.75rem;
}

.mingli-premium__eyebrow,
.mingli-premium__summary,
.mingli-premium__timeline-note,
.mingli-premium__section-text {
  margin: 0;
}

.mingli-premium__eyebrow {
  color: var(--ink-soft);
  letter-spacing: 0.18rem;
  font-size: 0.8rem;
}

.mingli-premium__title,
.mingli-premium__section-title,
.mingli-premium__timeline-title {
  margin: 0;
  font-family: var(--font-display);
}

.mingli-premium__title {
  font-size: 1.36rem;
}

.mingli-premium__summary,
.mingli-premium__section-text,
.mingli-premium__timeline-note {
  line-height: 1.88;
  text-indent: 2em;
  color: rgba(27, 21, 16, 0.9);
}

.mingli-premium__score {
  display: grid;
  justify-items: center;
  align-items: center;
  min-width: 5.8rem;
  padding: 0.9rem 1rem;
  border-radius: 1.15rem;
  background: linear-gradient(135deg, rgba(146, 71, 34, 0.96), rgba(98, 44, 24, 0.96));
  color: rgba(255, 245, 230, 0.96);
  box-shadow: 0 0.9rem 1.6rem rgba(98, 44, 24, 0.16);
}

.mingli-premium__score strong,
.mingli-premium__score span,
.mingli-premium__score p {
  margin: 0;
}

.mingli-premium__score strong {
  font-family: var(--font-display);
  font-size: 2.1rem;
  line-height: 1;
}

.mingli-premium__score span {
  font-size: 0.85rem;
}

.mingli-premium__score p {
  color: rgba(255, 237, 219, 0.82);
}

.mingli-premium__insight {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.mingli-premium__insight-card,
.mingli-premium__section-card,
.mingli-premium__timeline-card {
  padding: 0.9rem 0.95rem;
  border-radius: 1rem;
  border: 1px solid rgba(128, 93, 56, 0.1);
  background: linear-gradient(180deg, rgba(255, 252, 246, 0.96), rgba(245, 235, 214, 0.88));
}

.mingli-premium__visual,
.mingli-premium__timeline,
.mingli-premium__sections {
  display: grid;
  gap: 0.7rem;
}

.mingli-premium__visual-row {
  display: grid;
  grid-template-columns: 4.4rem minmax(0, 1fr);
  gap: 0.7rem;
  align-items: center;
}

.mingli-premium__visual-label {
  color: var(--ink-soft);
  font-size: 0.82rem;
}

.mingli-premium__visual-track {
  height: 0.55rem;
  border-radius: 999px;
  background: rgba(143, 117, 81, 0.15);
  overflow: hidden;
}

.mingli-premium__visual-fill {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, rgba(180, 121, 43, 0.96), rgba(224, 192, 106, 0.96));
}

.mingli-premium__timeline-title {
  font-size: 1rem;
}

.mingli-premium__section-title {
  font-size: 1.04rem;
}

.mingli-ai__heading,
.mingli-ai__text,
.mingli-ai__placeholder {
  margin: 0;
  line-height: 1.9;
}

.mingli-ai__heading {
  font-family: var(--font-display);
  font-size: 1.02rem;
  color: rgba(64, 39, 19, 0.94);
}

.mingli-ai__text {
  text-indent: 2em;
  color: rgba(27, 21, 16, 0.92);
}

.mingli-ai__placeholder {
  color: var(--ink-soft);
}

.mingli-ai__placeholder.is-error {
  color: rgba(148, 52, 34, 0.94);
}

.mingli-classics__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.85rem;
}

.mingli-geju {
  display: grid;
  gap: 0.9rem;
  padding: 0.95rem 1rem;
  border-radius: 1.15rem;
  border: 1px solid rgba(128, 93, 56, 0.12);
  background:
    radial-gradient(circle at 16% 14%, rgba(255, 255, 255, 0.2), transparent 22%),
    rgba(255, 250, 242, 0.8);
}

.mingli-geju__matched-title,
.mingli-geju__group-title,
.mingli-geju__card-name {
  margin: 0;
  font-family: var(--font-display);
}

.mingli-geju__matched-title {
  font-size: 1.08rem;
}

.mingli-geju__groups {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.9rem;
  align-items: start;
}

.mingli-geju__group {
  align-content: start;
}

.mingli-geju__group-head,
.mingli-geju__group-titles {
  display: grid;
  gap: 0.18rem;
}

.mingli-geju__group-title {
  font-size: 1.08rem;
}

.mingli-geju__group-meta,
.mingli-geju__card-meta {
  margin: 0;
  color: var(--ink-soft);
}

.mingli-geju__cards {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.7rem;
  margin-top: 0.75rem;
}

.mingli-geju__card {
  display: grid;
  gap: 0.35rem;
  padding: 0.78rem 0.84rem;
  border-radius: 1rem;
  border: 1px solid rgba(128, 93, 56, 0.1);
  background: linear-gradient(180deg, rgba(255, 252, 246, 0.96), rgba(245, 235, 214, 0.88));
}

.mingli-geju__card-name {
  font-size: 1rem;
}

.mingli-geju__card-text {
  margin: 0;
  line-height: 1.7;
  color: rgba(27, 21, 16, 0.88);
}

.mingli-geju__card-text--soft {
  color: var(--ink-soft);
}

.mingli-source {
  padding: 0.95rem 1rem;
  border-radius: 1rem;
  border: 1px solid rgba(128, 93, 56, 0.1);
  background: linear-gradient(180deg, rgba(255, 252, 246, 0.96), rgba(245, 235, 214, 0.88));
  display: grid;
  gap: 0.5rem;
}

.mingli-source__meta {
  color: var(--ink-soft);
  letter-spacing: 0.12rem;
}

.mingli-source__title {
  margin: 0;
  font-family: var(--font-display);
  font-size: 1.06rem;
}

.mingli-source__text {
  line-height: 1.88;
  color: rgba(27, 21, 16, 0.9);
}

.mingli-fold {
  display: grid;
  gap: 0;
}

.mingli-fold__summary {
  list-style: none;
  display: flex;
  justify-content: space-between;
  align-items: start;
  gap: 0.9rem;
  cursor: pointer;
}

.mingli-fold__summary::-webkit-details-marker {
  display: none;
}

.mingli-fold__meta {
  color: var(--ink-soft);
  white-space: nowrap;
}

.mingli-dayun {
  display: grid;
  gap: 0.9rem;
  padding: 0.95rem 1rem;
  border-radius: 1.15rem;
  border: 1px solid rgba(128, 93, 56, 0.12);
  background:
    radial-gradient(circle at 18% 16%, rgba(255, 255, 255, 0.2), transparent 24%),
    rgba(255, 250, 242, 0.82);
}

.mingli-dayun__head,
.mingli-dayun__route-head,
.mingli-dayun__cycle-top {
  display: flex;
  justify-content: space-between;
  gap: 0.9rem;
}

.mingli-dayun__head,
.mingli-dayun__route-head {
  align-items: start;
}

.mingli-dayun__titles,
.mingli-dayun__route-titles {
  display: grid;
  gap: 0.2rem;
}

.mingli-dayun__note,
.mingli-dayun__summary,
.mingli-dayun__route-verdict,
.mingli-dayun__route-summary,
.mingli-dayun__cycle-meta,
.mingli-dayun__cycle-note {
  margin: 0;
}

.mingli-dayun__note,
.mingli-dayun__route-verdict,
.mingli-dayun__cycle-meta {
  color: var(--ink-soft);
}

.mingli-dayun__summary,
.mingli-dayun__route-summary,
.mingli-dayun__cycle-note {
  color: rgba(27, 21, 16, 0.9);
  line-height: 1.84;
  text-indent: 2em;
}

.mingli-dayun__badge {
  align-self: start;
  padding: 0.45rem 0.8rem;
  border-radius: 999px;
  background: linear-gradient(180deg, rgba(110, 42, 24, 0.92), rgba(146, 60, 37, 0.92));
  color: rgba(255, 248, 238, 0.96);
  box-shadow: 0 0.8rem 1.6rem rgba(112, 62, 33, 0.14);
}

.mingli-dayun__routes {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.9rem;
  align-items: start;
}

.mingli-dayun__route {
  gap: 0.8rem;
}

.mingli-dayun__route .mingli-dayun__cycle-grid,
.mingli-classics__grid {
  margin-top: 0.75rem;
}

.mingli-dayun__route-title {
  margin: 0;
  font-family: var(--font-display);
  font-size: 1.08rem;
}

.mingli-dayun__route-score,
.mingli-dayun__cycle-score,
.mingli-dayun__cycle-title {
  font-family: var(--font-display);
}

.mingli-dayun__route-score {
  font-size: 1.3rem;
  line-height: 1;
}

.mingli-dayun__cycle-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.7rem;
}

.mingli-dayun__cycle {
  display: grid;
  gap: 0.36rem;
  padding: 0.85rem 0.92rem;
  border-radius: 1rem;
  border: 1px solid rgba(128, 93, 56, 0.1);
  background: linear-gradient(180deg, rgba(255, 252, 246, 0.96), rgba(245, 235, 214, 0.88));
}

.mingli-dayun__cycle-title {
  font-size: 1rem;
}

.mingli-dayun__cycle-score {
  font-size: 0.96rem;
}

.mingli-dayun__cycle-factors {
  font-size: 0.78rem;
  color: rgba(105, 77, 47, 0.82);
  letter-spacing: 0.01em;
}

@media (max-width: 1080px) {
  .mingli-hall__body,
  .mingli-report__main,
  .mingli-report__grid,
  .mingli-classics__grid,
  .mingli-score__breakdown,
  .mingli-dayun__routes,
  .mingli-geju__groups {
    grid-template-columns: 1fr;
  }

  .mingli-hall__sidebar {
    position: static;
    top: auto;
  }
}

@media (max-width: 820px) {
  .mingli-hall__heading,
  .mingli-report__hero {
    align-items: start;
  }

  .mingli-premium__cover {
    grid-template-columns: 1fr;
  }

  .mingli-term-grid,
  .mingli-report__metrics {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .mingli-premium__insight {
    grid-template-columns: 1fr;
  }

  .mingli-score__head {
    grid-template-columns: 1fr;
  }

  .mingli-dayun__head,
  .mingli-dayun__route-head {
    flex-direction: column;
  }

  .mingli-dayun__cycle-grid {
    grid-template-columns: 1fr;
  }

  .mingli-geju__cards {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 560px) {
  .mingli-term-grid,
  .mingli-report__metrics,
  .mingli-pillars,
  .mingli-report__grid,
  .mingli-classics__grid,
  .mingli-score__breakdown,
  .mingli-dayun__routes {
    grid-template-columns: 1fr;
  }
}

@media print {
  body * {
    visibility: hidden;
  }

  #mingli,
  #mingli .mingli-panel,
  #mingli .mingli-panel * {
    visibility: visible;
  }

  #mingli {
    display: block;
    margin: 0;
    padding: 0;
    background: #f7f1e4;
  }

  #mingli .mingli-hall__mist,
  #mingli .mingli-hall__head,
  #mingli .mingli-hall__sidebar {
    display: none !important;
  }

  #mingli .mingli-hall__body,
  #mingli .mingli-panel,
  #mingli .mingli-report {
    display: block;
    margin: 0;
    padding: 0;
    min-height: auto;
    background: transparent;
    box-shadow: none;
  }
}

.qi-scroll {
  isolation: isolate;
}

.qi-scroll__mist {
  position: absolute;
  width: 22rem;
  height: 22rem;
  border-radius: 50%;
  filter: blur(18px);
  opacity: 0.34;
  pointer-events: none;
}

.qi-scroll__mist--a {
  top: -7rem;
  left: -5rem;
  background: radial-gradient(circle, rgba(197, 164, 102, 0.22), transparent 72%);
}

.qi-scroll__mist--b {
  right: -5rem;
  bottom: -8rem;
  background: radial-gradient(circle, rgba(113, 147, 87, 0.16), transparent 72%);
}

.qi-scroll__head {
  position: relative;
  z-index: 1;
  margin-bottom: 1rem;
}

.qi-scroll__heading {
  display: flex;
  align-items: center;
  gap: 1rem;
}

.qi-scroll__seal {
  width: 4rem;
  height: 4rem;
  display: grid;
  place-items: center;
  border-radius: 50%;
  border: 1px solid rgba(157, 47, 32, 0.2);
  color: var(--vermillion);
  font-family: var(--font-display);
  font-size: 1.35rem;
  box-shadow: inset 0 0 0 0.28rem rgba(157, 47, 32, 0.06);
}

.qi-scroll__titles {
  display: grid;
  gap: 0.35rem;
}

.qi-scroll__label,
.qi-scroll__note,
.qi-scroll__detail-meta,
.qi-scroll__detail-note,
.qi-scroll__wing-meta,
.qi-scroll__season-note,
.qi-scroll__season-rail-text,
.qi-scroll__term-meta,
.qi-scroll__term-state,
.qi-scroll__ribbon-meta {
  margin: 0;
  color: var(--ink-soft);
}

.qi-scroll__label {
  letter-spacing: 0.18rem;
}

.qi-scroll__title {
  margin: 0;
  font-size: clamp(1.95rem, 3.3vw, 3rem);
  letter-spacing: 0.08rem;
}

.qi-scroll__note {
  max-width: 48rem;
  line-height: 1.82;
}

.qi-scroll__body {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.1rem;
  align-items: start;
}

.qi-scroll__aside,
.qi-scroll__canvas,
.qi-scroll__detail-card {
  position: relative;
  border-radius: 1.45rem;
  border: 1px solid rgba(125, 91, 55, 0.14);
  background: linear-gradient(180deg, rgba(253, 249, 239, 0.92), rgba(246, 238, 220, 0.88));
  box-shadow: 0 1rem 2.2rem rgba(60, 40, 22, 0.08);
  overflow: hidden;
}

.qi-scroll__aside::before,
.qi-scroll__canvas::before,
.qi-scroll__detail-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 14% 16%, rgba(255, 255, 255, 0.26), transparent 16%),
    linear-gradient(135deg, transparent 0 28%, rgba(157, 47, 32, 0.03) 46%, transparent 66%);
  pointer-events: none;
}

.qi-scroll__aside {
  padding: 1.05rem;
  display: grid;
  gap: 1rem;
}

.qi-scroll__season-nav {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.8rem;
}

.qi-scroll__detail {
  display: grid;
}

.qi-scroll__season-button {
  appearance: none;
  width: 100%;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 0.8rem;
  padding: 0.95rem 1rem;
  border-radius: 1.15rem;
  border: 1px solid rgba(128, 93, 56, 0.14);
  background: linear-gradient(180deg, rgba(255, 250, 241, 0.92), rgba(248, 239, 222, 0.8));
  box-shadow: 0 0.8rem 1.6rem rgba(60, 40, 22, 0.06);
  color: inherit;
  text-align: left;
  cursor: pointer;
  opacity: 0;
  transform: translateY(12px);
  animation: fadeSlide 0.55s ease forwards;
  animation-delay: var(--qi-season-delay, 0ms);
  transition: transform 0.3s ease, border-color 0.3s ease, box-shadow 0.3s ease, background 0.3s ease;
}

.qi-scroll__season-button:hover,
.qi-scroll__season-button.is-active {
  transform: translateY(-2px);
  border-color: color-mix(in srgb, var(--qi-accent, #7f8f57) 42%, rgba(128, 93, 56, 0.18));
  box-shadow: 0 1rem 2rem rgba(60, 40, 22, 0.08), 0 0 0 1px color-mix(in srgb, var(--qi-accent, #7f8f57) 16%, transparent);
}

.qi-scroll__season-button.is-active {
  background:
    radial-gradient(circle at 18% 18%, rgba(255, 255, 255, 0.24), transparent 24%),
    linear-gradient(180deg, color-mix(in srgb, var(--qi-wash, rgba(127, 143, 87, 0.18)) 42%, rgba(255, 251, 243, 0.92)), rgba(255, 248, 236, 0.94));
}

.qi-scroll__season-button.is-current .qi-scroll__season-seal {
  box-shadow: 0 0 0 0.35rem color-mix(in srgb, var(--qi-accent, #7f8f57) 10%, transparent);
}

.qi-scroll__season-seal {
  width: 2.35rem;
  height: 2.35rem;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: color-mix(in srgb, var(--qi-accent, #7f8f57) 86%, #5b3a26);
  color: #fbf2df;
  font-family: var(--font-display);
  font-size: 1rem;
}

.qi-scroll__season-copy {
  display: grid;
  gap: 0.2rem;
}

.qi-scroll__season-title {
  font-size: 1rem;
}

.qi-scroll__season-note {
  font-style: normal;
  line-height: 1.56;
}

.qi-scroll__detail-card {
  padding: 1.08rem;
  display: grid;
  gap: 1rem;
  min-height: 100%;
}

.qi-scroll__detail-head,
.qi-scroll__detail-hero {
  position: relative;
  z-index: 1;
}

.qi-scroll__detail-head {
  display: flex;
  gap: 1rem;
  align-items: center;
}

.qi-scroll__detail-seal {
  width: 4rem;
  height: 4rem;
  display: grid;
  place-items: center;
  border-radius: 1.15rem;
  background: linear-gradient(135deg, color-mix(in srgb, var(--qi-accent, #7f8f57) 88%, #7b271d), color-mix(in srgb, var(--qi-deep, #415233) 92%, #5b241d));
  color: #fbf2df;
  font-family: var(--font-display);
  font-size: 1.35rem;
  box-shadow: 0 0.9rem 1.8rem rgba(60, 40, 22, 0.12);
}

.qi-scroll__detail-titles {
  display: grid;
  gap: 0.28rem;
}

.qi-scroll__detail-title {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(1.8rem, 3vw, 2.6rem);
  letter-spacing: 0.08rem;
}

.qi-scroll__detail-hero {
  display: grid;
  gap: 0.9rem;
}

.qi-scroll__detail-hexagram {
  padding: 1rem 1.05rem;
  border-radius: 1.2rem;
  background: rgba(255, 251, 243, 0.76);
  border: 1px solid rgba(128, 93, 56, 0.12);
  display: grid;
  justify-items: start;
  gap: 0.55rem;
}

.qi-scroll__detail-hexagram-figure {
  padding: 0.85rem 1rem;
  border-radius: 1.08rem;
  background:
    radial-gradient(circle at 24% 18%, rgba(255, 255, 255, 0.28), transparent 24%),
    linear-gradient(180deg, rgba(255, 252, 246, 0.98), rgba(245, 235, 214, 0.88));
  border: 1px solid rgba(128, 93, 56, 0.14);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.52);
}

.qi-scroll__detail-hexagram-figure .figure {
  min-width: 9rem;
  gap: 0.28rem;
}

.qi-scroll__detail-hexagram-figure .figure__line {
  height: 0.34rem;
}

.qi-scroll__detail-wings {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.8rem;
}

.qi-scroll__wing {
  padding: 0.9rem;
  border-radius: 1.2rem;
  background: rgba(255, 251, 243, 0.74);
  border: 1px solid rgba(128, 93, 56, 0.12);
  display: grid;
  gap: 0.5rem;
}

.qi-scroll__wing--support {
  background: color-mix(in srgb, var(--qi-wash, rgba(127, 143, 87, 0.18)) 38%, rgba(255, 251, 243, 0.78));
}

.qi-scroll__wing-label {
  margin: 0;
  color: var(--ink-soft);
  letter-spacing: 0.14rem;
  font-size: 0.82rem;
}

.qi-scroll__wing-figure .figure {
  min-width: 8.2rem;
  gap: 0.42rem;
}

.qi-scroll__wing-title {
  margin: 0;
  font-family: var(--font-display);
  font-size: 1.18rem;
}

.qi-scroll__detail-summary {
  padding: 1rem 1.05rem;
  border-radius: 1.2rem;
  background: linear-gradient(180deg, color-mix(in srgb, var(--qi-wash, rgba(127, 143, 87, 0.18)) 44%, rgba(255, 251, 243, 0.9)), rgba(255, 251, 243, 0.76));
  border: 1px solid rgba(128, 93, 56, 0.12);
  display: grid;
  gap: 0.5rem;
}

.qi-scroll__detail-summary-title,
.qi-scroll__block-title,
.qi-scroll__ribbon-title {
  margin: 0;
  font-family: var(--font-display);
  letter-spacing: 0.08rem;
}

.qi-scroll__detail-summary-title {
  font-size: 1.18rem;
}

.qi-scroll__detail-summary-text,
.qi-scroll__block-text,
.qi-scroll__season-rail-text {
  margin: 0;
  line-height: 1.84;
  color: rgba(27, 21, 16, 0.84);
}

.qi-scroll__metrics {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.75rem;
}

.qi-scroll__metric {
  padding: 0.8rem 0.85rem;
  border-radius: 1rem;
  background: rgba(255, 251, 243, 0.72);
  border: 1px solid rgba(128, 93, 56, 0.12);
  display: grid;
  gap: 0.16rem;
}

.qi-scroll__metric-label {
  color: var(--ink-soft);
  font-size: 0.78rem;
  letter-spacing: 0.14rem;
}

.qi-scroll__metric-value {
  font-size: 0.98rem;
}

.qi-scroll__blocks {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.8rem;
}

.qi-scroll__block,
.qi-scroll__season-rail {
  padding: 1rem;
  border-radius: 1.18rem;
  background: rgba(255, 251, 243, 0.7);
  border: 1px solid rgba(128, 93, 56, 0.12);
}

.qi-scroll__observe-list,
.qi-scroll__season-term-list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
}

.qi-scroll__observe {
  padding: 0.42rem 0.72rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--qi-wash, rgba(127, 143, 87, 0.18)) 42%, rgba(255, 248, 236, 0.86));
  border: 1px solid rgba(189, 144, 67, 0.14);
  color: rgba(27, 21, 16, 0.82);
  font-size: 0.88rem;
}

.qi-scroll__season-term {
  appearance: none;
  border: 1px solid rgba(128, 93, 56, 0.14);
  background: rgba(255, 250, 241, 0.78);
  color: inherit;
  border-radius: 999px;
  padding: 0.45rem 0.85rem;
  cursor: pointer;
  transition: transform 0.25s ease, border-color 0.25s ease, background 0.25s ease;
}

.qi-scroll__season-term:hover,
.qi-scroll__season-term.is-active {
  transform: translateY(-2px);
  border-color: color-mix(in srgb, var(--qi-accent, #7f8f57) 34%, rgba(128, 93, 56, 0.18));
  background: color-mix(in srgb, var(--qi-wash, rgba(127, 143, 87, 0.18)) 44%, rgba(255, 248, 236, 0.9));
}

.qi-scroll__canvas {
  padding: 1.05rem;
  display: grid;
  gap: 0.9rem;
}

.qi-scroll__ribbon {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.75rem;
}

.qi-scroll__message-grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 0.75rem;
}

.qi-scroll__message-card {
  appearance: none;
  position: relative;
  padding: 0.85rem 0.8rem 0.9rem;
  border-radius: 1.12rem;
  border: 1px solid rgba(128, 93, 56, 0.12);
  background:
    radial-gradient(circle at 18% 16%, rgba(255, 255, 255, 0.26), transparent 22%),
    linear-gradient(180deg, rgba(255, 251, 243, 0.96), color-mix(in srgb, var(--qi-wash, rgba(127, 143, 87, 0.18)) 34%, rgba(248, 236, 214, 0.9)));
  color: inherit;
  text-align: left;
  cursor: pointer;
  opacity: 0;
  transform: translateY(10px);
  animation: fadeSlide 0.5s ease forwards;
  animation-delay: var(--qi-message-delay, 0ms);
  transition: transform 0.28s ease, box-shadow 0.28s ease, border-color 0.28s ease;
}

.qi-scroll__message-card:hover,
.qi-scroll__message-card.is-active {
  transform: translateY(-3px);
  border-color: color-mix(in srgb, var(--qi-accent, #7f8f57) 36%, rgba(128, 93, 56, 0.18));
  box-shadow: 0 1rem 2rem rgba(60, 40, 22, 0.08), 0 0 0 1px color-mix(in srgb, var(--qi-accent, #7f8f57) 12%, transparent);
}

.qi-scroll__message-card.is-current::after {
  content: "";
  position: absolute;
  inset: 0.42rem;
  border-radius: 0.84rem;
  border: 1px dashed color-mix(in srgb, var(--qi-accent, #7f8f57) 42%, transparent);
  pointer-events: none;
}

.qi-scroll__message-top {
  display: grid;
  gap: 0.12rem;
}

.qi-scroll__message-label,
.qi-scroll__message-terms,
.qi-scroll__message-meta {
  margin: 0;
  color: var(--ink-soft);
}

.qi-scroll__message-label {
  font-size: 0.72rem;
  letter-spacing: 0.14rem;
}

.qi-scroll__message-terms {
  font-size: 0.78rem;
  line-height: 1.45;
}

.qi-scroll__message-figure {
  margin: 0.55rem 0;
  padding: 0.5rem 0.58rem;
  border-radius: 0.95rem;
  background: rgba(255, 251, 243, 0.78);
  border: 1px solid rgba(128, 93, 56, 0.12);
}

.qi-scroll__message-figure .figure {
  min-width: auto;
  gap: 0.16rem;
}

.qi-scroll__message-figure .figure__line {
  height: 0.28rem;
}

.qi-scroll__message-title {
  margin: 0;
  font-family: var(--font-display);
  font-size: 1.02rem;
}

.qi-scroll__message-meta {
  margin-top: 0.14rem;
  font-size: 0.78rem;
  letter-spacing: 0.12rem;
}

.qi-scroll__ribbon-segment {
  padding: 0.9rem 1rem;
  border-radius: 1.15rem;
  background: linear-gradient(180deg, color-mix(in srgb, var(--qi-wash, rgba(127, 143, 87, 0.18)) 64%, rgba(255, 251, 243, 0.92)), rgba(255, 250, 241, 0.86));
  border: 1px solid rgba(128, 93, 56, 0.12);
  display: grid;
  gap: 0.3rem;
}

.qi-scroll__ribbon-title {
  font-size: 1.06rem;
}

.qi-scroll__ribbon-meta {
  line-height: 1.6;
  font-size: 0.88rem;
}

.qi-scroll__track {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  grid-template-rows: repeat(6, auto);
  grid-auto-flow: column;
  gap: 0.85rem;
  padding: 0.15rem 0 0;
  align-items: stretch;
}

.qi-scroll__track::before {
  display: none;
}

.qi-scroll__term {
  appearance: none;
  position: relative;
  min-height: 14.8rem;
  padding: 1.05rem 1rem;
  border-radius: 1.28rem;
  border: 1px solid rgba(128, 93, 56, 0.12);
  background:
    radial-gradient(circle at 18% 18%, rgba(255, 255, 255, 0.26), transparent 20%),
    linear-gradient(180deg, rgba(255, 251, 243, 0.96), color-mix(in srgb, var(--qi-wash, rgba(127, 143, 87, 0.18)) 44%, rgba(248, 236, 214, 0.9)));
  box-shadow: 0 1rem 2rem rgba(60, 40, 22, 0.07);
  display: grid;
  align-content: start;
  text-align: left;
  color: inherit;
  cursor: pointer;
  opacity: 0;
  transform: translateY(12px);
  animation: fadeSlide 0.55s ease forwards;
  animation-delay: var(--qi-term-delay, 0ms);
  transition: transform 0.28s ease, box-shadow 0.28s ease, border-color 0.28s ease;
}

.qi-scroll__term:hover,
.qi-scroll__term.is-active {
  transform: translateY(-4px);
  border-color: color-mix(in srgb, var(--qi-accent, #7f8f57) 34%, rgba(128, 93, 56, 0.18));
  box-shadow: 0 1.2rem 2.2rem rgba(60, 40, 22, 0.1), 0 0 0 1px color-mix(in srgb, var(--qi-accent, #7f8f57) 12%, transparent);
}

.qi-scroll__term.is-current::after {
  content: "";
  position: absolute;
  inset: 0.55rem;
  border-radius: 0.9rem;
  border: 1px dashed color-mix(in srgb, var(--qi-accent, #7f8f57) 42%, transparent);
  pointer-events: none;
}

.qi-scroll__term-top {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 0.75rem;
}

.qi-scroll__term-badge {
  padding: 0.25rem 0.62rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--qi-accent, #7f8f57) 16%, rgba(255, 248, 236, 0.82));
  color: color-mix(in srgb, var(--qi-deep, #415233) 84%, #fff);
  font-size: 0.76rem;
  letter-spacing: 0.1rem;
}

.qi-scroll__term-title {
  margin: 0.65rem 0 0.2rem;
  font-family: var(--font-display);
  font-size: clamp(1.42rem, 1.7vw, 1.72rem);
  letter-spacing: 0.08rem;
  line-height: 1.1;
}

.qi-scroll__term-state {
  line-height: 1.6;
}

.qi-scroll__term-pair {
  margin-top: 0.8rem;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 0.7rem;
  align-items: center;
}

.qi-scroll__term-figure {
  width: 3.6rem;
  padding: 0.45rem;
  border-radius: 0.92rem;
  background: rgba(255, 251, 243, 0.74);
  border: 1px solid rgba(128, 93, 56, 0.12);
}

.qi-scroll__term-figure--support {
  translate: -0.4rem 0.55rem;
}

.qi-scroll__term-figure--hexagram {
  width: auto;
  padding: 0.55rem 0.68rem;
}

.qi-scroll__term-figure.qi-scroll__term-figure--hexagram .figure {
  min-width: 5.6rem;
  gap: 0.16rem;
}

.qi-scroll__term-figure.qi-scroll__term-figure--hexagram .figure__line {
  height: 0.28rem;
}

.qi-scroll__term-figure .figure {
  min-width: auto;
  gap: 0.16rem;
}

.qi-scroll__term-figure .figure__line {
  height: 0.3rem;
}

.qi-scroll__term-pair-copy {
  display: grid;
  gap: 0.08rem;
}

.qi-scroll__term-pair-copy strong,
.qi-scroll__term-pair-copy em {
  font-family: var(--font-display);
  font-style: normal;
}

.qi-scroll__term-pair-copy span {
  color: var(--ink-soft);
  font-size: 0.8rem;
  letter-spacing: 0.12rem;
}

.qi-scroll__term-line {
  margin: auto 0 0;
  padding-top: 0.85rem;
  border-top: 1px solid rgba(128, 93, 56, 0.08);
  line-height: 1.8;
  color: rgba(27, 21, 16, 0.8);
}

.xiang-hall {
  isolation: isolate;
}

.xiang-hall__mist {
  position: absolute;
  width: 18rem;
  height: 18rem;
  border-radius: 50%;
  filter: blur(14px);
  opacity: 0.36;
  pointer-events: none;
}

.xiang-hall__mist--a {
  top: -4rem;
  right: -3rem;
  background: radial-gradient(circle, rgba(216, 182, 124, 0.26), transparent 72%);
}

.xiang-hall__mist--b {
  bottom: -6rem;
  left: -4rem;
  background: radial-gradient(circle, rgba(146, 55, 40, 0.16), transparent 72%);
}

.xiang-hall__heading {
  display: flex;
  align-items: center;
  gap: 1rem;
}

.xiang-hall__seal {
  width: 4.2rem;
  height: 4.2rem;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background:
    radial-gradient(circle at 30% 20%, rgba(255, 255, 255, 0.24), transparent 28%),
    linear-gradient(135deg, rgba(157, 47, 32, 0.96), rgba(121, 26, 19, 0.96));
  color: #fbf2df;
  font-family: var(--font-display);
  font-size: 1.15rem;
  letter-spacing: 0.08rem;
  box-shadow: 0 1rem 2rem rgba(125, 31, 23, 0.18);
}

.xiang-hall__titles {
  display: grid;
  gap: 0.35rem;
}

.xiang-hall__label,
.xiang-hall__note {
  margin: 0;
  color: var(--ink-soft);
}

.xiang-hall__label {
  letter-spacing: 0.18rem;
}

.xiang-hall__note {
  max-width: 34rem;
  line-height: 1.78;
}

.xiang-hall__body {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(320px, 360px) minmax(0, 1fr);
  gap: 1rem;
  margin-top: 1rem;
  align-items: start;
}

.xiang-hall__sidebar,
.xiang-panel__article {
  position: relative;
  border-radius: 1.45rem;
  border: 1px solid rgba(125, 91, 55, 0.14);
  background: linear-gradient(180deg, rgba(253, 249, 239, 0.92), rgba(246, 238, 220, 0.88));
  box-shadow: 0 1rem 2.2rem rgba(60, 40, 22, 0.08);
  overflow: hidden;
}

.xiang-hall__sidebar::before,
.xiang-panel__article::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 14% 16%, rgba(255, 255, 255, 0.28), transparent 16%),
    linear-gradient(135deg, transparent 0 28%, rgba(157, 47, 32, 0.03) 46%, transparent 66%);
  pointer-events: none;
}

.xiang-hall__sidebar {
  padding: 1rem;
  display: grid;
  gap: 1rem;
}

.xiang-nav {
  display: grid;
  gap: 0.7rem;
}

.xiang-nav__button {
  appearance: none;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 0.8rem;
  width: 100%;
  padding: 0.95rem 1rem;
  border-radius: 1.15rem;
  border: 1px solid rgba(128, 93, 56, 0.14);
  background: rgba(255, 250, 241, 0.68);
  color: inherit;
  text-align: left;
  cursor: pointer;
  opacity: 0;
  transform: translateY(12px);
  animation: fadeSlide 0.55s ease forwards;
  animation-delay: var(--xiang-delay, 0ms);
  transition: transform 0.3s ease, border-color 0.3s ease, box-shadow 0.3s ease, background 0.3s ease;
}

.xiang-nav__button:hover,
.xiang-nav__button.is-active {
  transform: translateY(-2px);
}

.xiang-nav__button.is-active {
  border-color: rgba(202, 159, 72, 0.38);
  box-shadow: 0 1rem 2rem rgba(60, 40, 22, 0.08), 0 0 0 1px rgba(202, 159, 72, 0.1);
  background: linear-gradient(180deg, rgba(255, 250, 241, 0.96), rgba(248, 236, 206, 0.92));
}

.xiang-nav__seal {
  width: 2.3rem;
  height: 2.3rem;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: rgba(148, 43, 28, 0.9);
  color: #f8f0df;
  font-family: var(--font-display);
  font-size: 1rem;
}

.xiang-nav__copy {
  display: grid;
  gap: 0.22rem;
}

.xiang-nav__title {
  font-size: 1rem;
}

.xiang-nav__note {
  margin: 0;
  font-style: normal;
  color: rgba(27, 21, 16, 0.68);
  line-height: 1.58;
}

.xiang-items {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.75rem;
}

.xiang-item {
  appearance: none;
  display: grid;
  gap: 0.45rem;
  width: 100%;
  padding: 0.9rem;
  border-radius: 1.1rem;
  border: 1px solid rgba(128, 93, 56, 0.12);
  background: rgba(255, 251, 243, 0.76);
  text-align: left;
  color: inherit;
  cursor: pointer;
  opacity: 0;
  transform: translateY(12px);
  animation: fadeSlide 0.55s ease forwards;
  animation-delay: var(--xiang-item-delay, 0ms);
  transition: transform 0.28s ease, border-color 0.28s ease, box-shadow 0.28s ease, background 0.28s ease;
}

.xiang-item:hover,
.xiang-item.is-active {
  transform: translateY(-2px);
}

.xiang-item.is-active {
  border-color: rgba(202, 159, 72, 0.38);
  box-shadow: 0 0.9rem 1.8rem rgba(60, 40, 22, 0.08), 0 0 0 1px rgba(202, 159, 72, 0.1);
  background: linear-gradient(180deg, rgba(255, 251, 243, 0.98), rgba(247, 236, 214, 0.96));
}

.xiang-item__title {
  font-family: var(--font-display);
  font-size: 1.05rem;
  letter-spacing: 0.05rem;
}

.xiang-item__trigram {
  color: var(--ink-soft);
  font-size: 0.84rem;
  letter-spacing: 0.14rem;
}

.xiang-item__line {
  margin: 0;
  color: rgba(27, 21, 16, 0.78);
  line-height: 1.7;
  font-size: 0.92rem;
}

.xiang-panel__article {
  padding: 1.15rem;
  display: grid;
  gap: 1rem;
}

.xiang-panel__header,
.xiang-panel__hero {
  position: relative;
  z-index: 1;
}

.xiang-panel__header {
  display: flex;
  gap: 1rem;
  align-items: center;
  padding-bottom: 0.9rem;
  border-bottom: 1px solid rgba(122, 89, 54, 0.12);
}

.xiang-panel__seal {
  width: 4rem;
  height: 4rem;
  display: grid;
  place-items: center;
  border-radius: 1.1rem;
  background: linear-gradient(135deg, rgba(157, 47, 32, 0.96), rgba(121, 26, 19, 0.96));
  color: #fbf2df;
  font-family: var(--font-display);
  font-size: 1.4rem;
  box-shadow: 0 0.9rem 1.8rem rgba(125, 31, 23, 0.14);
}

.xiang-panel__titles {
  display: grid;
  gap: 0.28rem;
}

.xiang-panel__meta,
.xiang-panel__note,
.xiang-panel__summary-text,
.xiang-panel__bridge-text,
.xiang-panel__block-text--muted {
  margin: 0;
  color: var(--ink-soft);
}

.xiang-panel__title {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(2rem, 3.5vw, 2.8rem);
  letter-spacing: 0.08rem;
}

.xiang-panel__hero {
  display: grid;
  grid-template-columns: minmax(220px, 270px) minmax(0, 1fr);
  gap: 1rem;
}

.xiang-panel__visual {
  min-height: 15rem;
}

.xiang-panel__summary {
  display: grid;
  gap: 0.75rem;
  align-content: center;
}

.xiang-panel__summary-title {
  margin: 0;
  font-family: var(--font-display);
  font-size: 1.55rem;
}

.xiang-panel__summary-text {
  line-height: 1.86;
}

.xiang-panel__figure .figure {
  min-width: 10rem;
  gap: 0.72rem;
}

.xiang-panel__figure .figure__line {
  height: 0.92rem;
}

.xiang-panel__metrics {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 0.7rem;
}

.xiang-panel__metric {
  padding: 0.78rem 0.8rem;
  border-radius: 1rem;
  background: rgba(255, 251, 243, 0.72);
  border: 1px solid rgba(128, 93, 56, 0.12);
  display: grid;
  gap: 0.18rem;
}

.xiang-panel__metric-label {
  color: var(--ink-soft);
  font-size: 0.78rem;
  letter-spacing: 0.14rem;
}

.xiang-panel__metric-value {
  font-size: 0.98rem;
}

.xiang-panel__blocks {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.9rem;
}

.xiang-panel__block,
.xiang-panel__bridge {
  padding: 1rem;
  border-radius: 1.2rem;
  background: rgba(255, 251, 243, 0.7);
  border: 1px solid rgba(128, 93, 56, 0.12);
}

.xiang-panel__block-title {
  margin: 0 0 0.7rem;
  font-family: var(--font-display);
  font-size: 1.12rem;
  letter-spacing: 0.08rem;
}

.xiang-panel__block-text {
  margin: 0;
  line-height: 1.82;
  color: rgba(27, 21, 16, 0.84);
}

.xiang-panel__block-text + .xiang-panel__block-text {
  margin-top: 0.55rem;
}

.xiang-panel__keyword-list,
.xiang-panel__qualities,
.xiang-panel__related-list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
}

.xiang-panel__keyword,
.xiang-panel__quality {
  padding: 0.42rem 0.72rem;
  border-radius: 999px;
  background: rgba(248, 236, 206, 0.74);
  border: 1px solid rgba(189, 144, 67, 0.14);
  color: rgba(27, 21, 16, 0.82);
  font-size: 0.88rem;
}

.xiang-panel__bridge {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 0.75rem;
}

.xiang-panel__related {
  appearance: none;
  border: 1px solid rgba(128, 93, 56, 0.14);
  background: rgba(255, 250, 241, 0.76);
  color: inherit;
  border-radius: 999px;
  padding: 0.45rem 0.85rem;
  cursor: pointer;
  transition: transform 0.25s ease, border-color 0.25s ease, background 0.25s ease;
}

.xiang-panel__related:hover {
  transform: translateY(-2px);
  border-color: rgba(202, 159, 72, 0.38);
  background: rgba(248, 236, 206, 0.92);
}

.divination-insights {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
  margin-top: 1.15rem;
}

.body-use--result {
  margin: 0;
}

.timing-panel__head {
  position: relative;
  z-index: 1;
  padding: 1rem 1rem 0;
}

.timing-panel__title {
  margin: 0;
  font-family: var(--font-display);
  font-size: 1.45rem;
  letter-spacing: 0.1rem;
}

.timing-panel__body {
  position: relative;
  z-index: 1;
  padding: 1rem;
}

.timing-panel__article {
  display: grid;
  gap: 1rem;
}

.timing-panel__verdict {
  display: grid;
  gap: 0.45rem;
  padding: 1rem;
  border-radius: 1.1rem;
  background: rgba(255, 251, 243, 0.76);
  border: 1px solid rgba(202, 159, 72, 0.12);
}

.timing-panel__verdict-title {
  font-family: var(--font-display);
  font-size: 1.8rem;
  color: rgba(39, 25, 15, 0.94);
}

.timing-panel__verdict-hint {
  margin: 0;
  color: rgba(27, 21, 16, 0.84);
  line-height: 1.82;
}

.timing-panel__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.85rem;
}

.timing-panel__stage {
  display: grid;
  gap: 0.55rem;
  padding: 0.9rem;
  border-radius: 1rem;
  background: rgba(255, 251, 243, 0.74);
  border: 1px solid rgba(202, 159, 72, 0.12);
  opacity: 0;
  transform: translateY(10px);
  animation: fadeSlide 0.55s ease forwards;
  animation-delay: var(--timing-delay, 0ms);
}

.timing-panel__stage-label,
.timing-panel__stage-text {
  margin: 0;
  color: var(--ink-soft);
  line-height: 1.82;
}

.timing-panel__stage-name {
  margin: 0;
  font-family: var(--font-display);
  font-size: 1.1rem;
}

.timing-panel__stage-figure .figure {
  min-width: 6.6rem;
  gap: 0.42rem;
}

.timing-panel__stage-figure .figure__line {
  height: 0.68rem;
}

.timing-panel__quotes {
  display: grid;
  gap: 0.7rem;
}

.timing-panel__quote {
  margin: 0;
  padding: 0.95rem 1rem;
  border-radius: 1rem;
  background: rgba(255, 251, 243, 0.74);
  border: 1px solid rgba(202, 159, 72, 0.12);
  line-height: 1.9;
  opacity: 0;
  transform: translateY(10px);
  animation: fadeSlide 0.55s ease forwards;
  animation-delay: var(--timing-quote-delay, 0ms);
}

.cast-flow-entry {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1rem 1.1rem;
  margin-top: 1rem;
}

.cast-flow-entry__copy {
  display: grid;
  gap: 0.32rem;
}

.cast-flow-entry__label {
  margin: 0;
  color: var(--ink-soft);
  letter-spacing: 0.18rem;
}

.cast-flow-entry__title {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(1.4rem, 2.8vw, 2rem);
}

.cast-flow-entry__button {
  flex-shrink: 0;
}

.screen-castflow__mist {
  position: absolute;
  width: 30rem;
  height: 30rem;
  border-radius: 50%;
  filter: blur(28px);
}

.screen-castflow__mist--a {
  left: 5%;
  top: 10%;
  background: radial-gradient(circle, rgba(255, 245, 217, 0.24), transparent 72%);
  animation: washFloat 13s ease-in-out infinite;
}

.screen-castflow__mist--b {
  right: 4%;
  bottom: 6%;
  background: radial-gradient(circle, rgba(202, 159, 72, 0.18), transparent 70%);
  animation: washFloat 16s ease-in-out infinite reverse;
}

.screen-castflow__inner {
  position: relative;
  width: min(94vw, 1280px);
  height: min(90vh, 860px);
  padding: 1.1rem;
  display: grid;
  gap: 1rem;
}

.screen-castflow__topbar {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  align-items: start;
  padding: 0.3rem 0;
}

.screen-castflow__titles {
  display: grid;
  gap: 0.42rem;
}

.screen-castflow__label,
.screen-castflow__subtitle {
  margin: 0;
  color: rgba(245, 229, 192, 0.76);
  letter-spacing: 0.18rem;
}

.screen-castflow__title {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(2rem, 4vw, 3.3rem);
  color: #f8eacc;
  letter-spacing: 0.14rem;
}

.screen-castflow__actions {
  display: flex;
  gap: 0.8rem;
  flex-wrap: wrap;
}

.screen-castflow__button {
  appearance: none;
  min-height: 3rem;
  padding: 0.7rem 1.5rem;
  border-radius: 999px;
  border: 1px solid rgba(240, 208, 135, 0.36);
  background: linear-gradient(135deg, rgba(157, 47, 32, 0.94), rgba(121, 26, 19, 0.94));
  color: #fdf3df;
  cursor: pointer;
  letter-spacing: 0.18rem;
}

.screen-castflow__button--ghost {
  background: rgba(255, 250, 242, 0.08);
}

.screen-castflow__body {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(250px, 300px);
  gap: 1rem;
  min-height: 0;
}

.screen-castflow__stage {
  position: relative;
  min-height: 0;
  border-radius: 2rem;
  overflow: hidden;
  border: 1px solid rgba(240, 208, 135, 0.18);
  background:
    radial-gradient(circle at 50% 40%, rgba(255, 244, 212, 0.12), transparent 22%),
    linear-gradient(180deg, rgba(72, 42, 18, 0.82), rgba(25, 15, 8, 0.92));
}

.screen-castflow__stream,
.screen-castflow__ornament {
  position: absolute;
  pointer-events: none;
}

.screen-castflow__stream {
  top: 50%;
  width: 32%;
  height: 0.15rem;
  background: linear-gradient(90deg, transparent, rgba(240, 208, 135, 0.82), transparent);
  opacity: 0.3;
}

.screen-castflow__stream--left {
  left: 8%;
  animation: evolutionStreamLeft 2.4s ease-in-out infinite;
}

.screen-castflow__stream--right {
  right: 8%;
  animation: evolutionStreamRight 2.4s ease-in-out infinite;
}

.screen-castflow__ornament {
  width: 15rem;
  height: 15rem;
  border-radius: 50%;
  border: 1px dashed rgba(240, 208, 135, 0.16);
  animation: spinSlow 18s linear infinite;
}

.screen-castflow__ornament--a {
  left: 6%;
  top: 14%;
}

.screen-castflow__ornament--b {
  right: 8%;
  bottom: 12%;
  animation-direction: reverse;
}

.screen-castflow__sigil,
.screen-castflow__step,
.screen-castflow__name {
  position: absolute;
  left: 50%;
  translate: -50% 0;
  text-align: center;
}

.screen-castflow__sigil {
  top: 1.35rem;
  width: 5rem;
  height: 5rem;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background:
    radial-gradient(circle at 30% 20%, rgba(255, 255, 255, 0.18), transparent 28%),
    linear-gradient(135deg, rgba(157, 47, 32, 0.98), rgba(121, 26, 19, 0.96));
  color: #fbf2df;
  font-family: var(--font-display);
  font-size: 1.55rem;
  box-shadow: 0 1rem 2rem rgba(125, 31, 23, 0.18);
}

.screen-castflow__step {
  top: 7.1rem;
  margin: 0;
  color: rgba(245, 229, 192, 0.8);
  letter-spacing: 0.22rem;
}

.screen-castflow__name {
  bottom: 2.2rem;
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(2rem, 4vw, 3.1rem);
  color: #faedd0;
  text-shadow: 0 0.2rem 1rem rgba(0, 0, 0, 0.18);
}

.screen-castflow__assembly {
  position: absolute;
  inset: 11rem 8rem 7.5rem;
}

.castflow-line {
  position: absolute;
  left: 50%;
  top: calc(1rem + var(--row-index) * 3rem);
  height: 1.05rem;
  display: grid;
  align-items: center;
  opacity: 0;
  transform: translate(calc(-50% + var(--from-x)), 0) scale(0.62);
  transition: transform 0.9s cubic-bezier(0.2, 0.82, 0.2, 1), opacity 0.9s ease;
}

.castflow-line.is-yang {
  grid-template-columns: 1fr;
  width: 18rem;
}

.castflow-line.is-yin {
  grid-template-columns: 1fr 1.15rem 1fr;
  gap: 0.5rem;
  width: 18rem;
}

.castflow-line__gap {
  width: 100%;
  height: 100%;
}

.castflow-line__stroke {
  height: 100%;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(190, 145, 63, 0.98), rgba(240, 208, 135, 0.96));
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.08), 0 0 1.2rem rgba(202, 159, 72, 0.24);
}

.castflow-line.is-moving .castflow-line__stroke {
  background: linear-gradient(90deg, rgba(233, 190, 77, 1), rgba(255, 231, 164, 1));
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.16), 0 0 1.5rem rgba(240, 208, 135, 0.6);
}

.screen-castflow__assembly.is-settled .castflow-line {
  opacity: 1;
  transform: translate(-50%, 0) scale(1);
}

.screen-castflow__assembly.is-break .castflow-line {
  opacity: 0;
  transform: translate(calc(-50% + var(--scatter-x)), var(--scatter-y)) scale(0.64) rotate(var(--scatter-rotate));
}

.screen-castflow__rail {
  display: grid;
  gap: 0.8rem;
  align-content: start;
  padding: 1rem;
  border-radius: 1.5rem;
  border: 1px solid rgba(240, 208, 135, 0.18);
  background: rgba(40, 24, 12, 0.68);
}

.screen-castflow__marker {
  appearance: none;
  display: grid;
  gap: 0.25rem;
  width: 100%;
  padding: 0.9rem 1rem;
  border-radius: 1rem;
  border: 1px solid rgba(240, 208, 135, 0.14);
  background: rgba(255, 249, 236, 0.06);
  color: #f7ead0;
  text-align: left;
  cursor: pointer;
  transition: transform 0.3s ease, border-color 0.3s ease, background 0.3s ease;
}

.screen-castflow__marker:hover,
.screen-castflow__marker.is-active {
  transform: translateY(-2px);
  border-color: rgba(240, 208, 135, 0.34);
  background: rgba(255, 249, 236, 0.1);
}

.screen-castflow__marker-label {
  color: rgba(245, 229, 192, 0.72);
  letter-spacing: 0.18rem;
  font-size: 0.84rem;
}

.screen-castflow__marker-name {
  font-family: var(--font-display);
  font-size: 1.05rem;
}

.relation-map {
  padding-bottom: 1rem;
}

.relation-map__current,
.relation-map__graph,
.relation-map__detail {
  position: relative;
  z-index: 1;
  margin: 0 1rem;
}

.relation-map__current {
  margin-top: 0.9rem;
}

.relation-map__current-card {
  padding: 0.95rem 1rem;
  border-radius: 1rem;
  background: rgba(255, 251, 243, 0.76);
  border: 1px solid rgba(202, 159, 72, 0.12);
}

.relation-map__current-name {
  margin: 0;
  font-family: var(--font-display);
  font-size: 1.25rem;
}

.relation-map__current-line {
  margin: 0.4rem 0 0;
  color: rgba(27, 21, 16, 0.78);
  line-height: 1.8;
}

.relation-map__graph {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.8rem;
  margin-top: 1rem;
}

.relation-node {
  appearance: none;
  display: grid;
  gap: 0.45rem;
  align-content: start;
  padding: 0.9rem;
  border-radius: 1rem;
  border: 1px solid rgba(202, 159, 72, 0.12);
  background: rgba(255, 251, 243, 0.72);
  text-align: left;
  color: inherit;
  cursor: pointer;
  transition: transform 0.35s ease, border-color 0.35s ease, box-shadow 0.35s ease;
}

.relation-node:hover {
  transform: translateY(-2px);
}

.relation-node--base {
  grid-column: 2;
  grid-row: 2;
}

.relation-node--mutual {
  grid-column: 2;
  grid-row: 1;
}

.relation-node--reverse {
  grid-column: 1;
  grid-row: 2;
}

.relation-node--changed {
  grid-column: 3;
  grid-row: 2;
}

.relation-node--opposite {
  grid-column: 2;
  grid-row: 3;
}

.relation-node.is-active {
  border-color: rgba(202, 159, 72, 0.42);
  box-shadow: 0 1.1rem 2.2rem rgba(60, 40, 22, 0.08), 0 0 0 1px rgba(202, 159, 72, 0.12);
  background: linear-gradient(180deg, rgba(255, 250, 241, 0.94), rgba(248, 239, 217, 0.9));
}

.relation-node__label {
  color: var(--ink-soft);
  font-size: 0.82rem;
  letter-spacing: 0.16rem;
}

.relation-node__name {
  font-family: var(--font-display);
  font-size: 1.08rem;
  line-height: 1.45;
}

.relation-node__figure .figure {
  min-width: 6.2rem;
  gap: 0.42rem;
}

.relation-node__figure .figure__line {
  height: 0.66rem;
}

.relation-map__detail {
  margin-top: 1rem;
}

.relation-detail__article {
  padding: 1rem;
  border-radius: 1rem;
  background: rgba(255, 251, 243, 0.76);
  border: 1px solid rgba(202, 159, 72, 0.12);
}

.relation-detail__label {
  margin: 0;
  color: var(--ink-soft);
  letter-spacing: 0.16rem;
}

.relation-detail__title {
  margin: 0.4rem 0 0;
  font-family: var(--font-display);
  font-size: 1.45rem;
}

.relation-detail__figure {
  margin-top: 0.8rem;
}

.relation-detail__figure .figure {
  min-width: 8rem;
  gap: 0.5rem;
}

.relation-detail__figure .figure__line {
  height: 0.74rem;
}

.relation-detail__text {
  margin: 0.8rem 0 0;
  line-height: 1.9;
  color: rgba(27, 21, 16, 0.88);
}

.scroll-panel__section {
  margin-top: 1rem;
  padding: 1rem;
  border-radius: 1rem;
  background: rgba(255, 248, 234, 0.76);
  border: 1px solid rgba(202, 159, 72, 0.12);
  opacity: 0;
  transform: translateY(12px);
  animation: fadeSlide 0.55s ease forwards;
  animation-delay: var(--scroll-section-delay, 0ms);
}

.scroll-panel__section-title,
.scroll-panel__entry-title {
  margin: 0;
  color: var(--ink-soft);
  letter-spacing: 0.16rem;
}

.scroll-panel__section-title {
  font-family: var(--font-display);
  font-size: 1.2rem;
  color: rgba(27, 21, 16, 0.88);
}

.scroll-panel__entry-title {
  margin-top: 0.85rem;
}

.scroll-panel__text {
  margin: 0.55rem 0 0;
  line-height: 1.92;
  color: rgba(27, 21, 16, 0.88);
}

.method-switch { display: flex; flex-wrap: wrap; gap: 0.75rem; }

.method-switch__button {
  appearance: none;
  border: 1px solid rgba(157, 47, 32, 0.14);
  background: rgba(255, 250, 242, 0.58);
  color: var(--ink-soft);
  padding: 0.72rem 1.15rem;
  border-radius: 999px;
  cursor: pointer;
  transition: transform 0.35s ease, border-color 0.35s ease, background 0.35s ease, color 0.35s ease;
}

.method-switch__button.is-active {
  background: linear-gradient(135deg, rgba(157, 47, 32, 0.96), rgba(125, 31, 23, 0.96));
  color: #fbf2df;
  border-color: rgba(157, 47, 32, 0.28);
  box-shadow: 0 0.9rem 1.8rem rgba(125, 31, 23, 0.16);
}

.method-switch__button:hover { transform: translateY(-1px); }

.panel__forms {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 1rem;
}

.topic-field {
  display: grid;
  gap: 0.6rem;
  padding: 1rem;
  border-radius: 1.3rem;
  border: 1px solid rgba(120, 88, 53, 0.16);
  background: rgba(252, 248, 239, 0.68);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.18);
}

.topic-field__label { font-size: 0.92rem; letter-spacing: 0.18rem; color: var(--ink-soft); }

.topic-field textarea {
  width: 100%;
  border: 0;
  outline: none;
  resize: vertical;
  min-height: 5.2rem;
  background: transparent;
  color: var(--ink);
  line-height: 1.8;
}

.method-panels { display: grid; }

.method-panel {
  display: none;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.9rem;
}

.method-panel.is-active { display: grid; animation: fadeSlide 0.45s ease both; }

.field {
  display: inline-flex;
  align-items: center;
  gap: 0.7rem;
  min-height: 3.4rem;
  padding: 0.65rem 0.95rem;
  border-radius: 999px;
  background: rgba(252, 247, 236, 0.78);
  border: 1px solid rgba(120, 88, 53, 0.18);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.24);
}

.field--search { min-width: min(100%, 16rem); }
.field__label { color: var(--ink-soft); font-size: 0.92rem; letter-spacing: 0.16rem; }

.field input {
  min-width: 0;
  width: 100%;
  border: 0;
  outline: none;
  background: transparent;
  color: var(--ink);
}

.field input::placeholder,
.topic-field textarea::placeholder { color: rgba(27, 21, 16, 0.36); }

.panel__actions { display: flex; gap: 0.9rem; }

.panel__button {
  appearance: none;
  min-height: 3.35rem;
  padding: 0.8rem 1.9rem;
  border-radius: 999px;
  border: 1px solid rgba(157, 47, 32, 0.32);
  background: linear-gradient(135deg, rgba(157, 47, 32, 0.96), rgba(125, 31, 23, 0.96));
  color: #faf2e2;
  cursor: pointer;
  letter-spacing: 0.2rem;
  box-shadow: 0 1rem 2rem rgba(125, 31, 23, 0.16);
  transition: transform 0.35s ease, box-shadow 0.35s ease;
}

.panel__button:hover { transform: translateY(-2px); box-shadow: 0 1.3rem 2.4rem rgba(125, 31, 23, 0.22); }
.panel__button:disabled { cursor: wait; opacity: 0.78; }

.casting {
  display: none;
}

.casting.is-active { animation: castingAppear 1.2s ease forwards; }

.casting__ring,
.casting__seal {
  position: absolute;
  inset: 50%;
  translate: -50% -50%;
}

.casting__ring {
  border-radius: 50%;
  border: 1px solid rgba(240, 208, 135, 0.72);
  box-shadow: 0 0 1.2rem rgba(240, 208, 135, 0.18);
}

.casting__ring--a { width: 9rem; height: 9rem; animation: spinSlow 2s linear infinite; }
.casting__ring--b { width: 12rem; height: 12rem; border-style: dashed; animation: spinSlow 3s linear infinite reverse; }
.casting__ring--c { width: 15rem; height: 15rem; opacity: 0.42; animation: pulseRing 1.2s ease infinite; }

.casting__seal {
  width: 4.6rem;
  height: 4.6rem;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: radial-gradient(circle at 30% 20%, rgba(255, 255, 255, 0.24), transparent 30%), linear-gradient(135deg, rgba(157, 47, 32, 0.96), rgba(121, 26, 19, 0.96));
  color: #fbf2df;
  font-family: var(--font-display);
  font-size: 1.8rem;
  box-shadow: 0 1rem 2.4rem rgba(125, 31, 23, 0.22);
}

.casting__dust { position: absolute; inset: 0; }

.casting__spark {
  background: radial-gradient(circle, rgba(240, 208, 135, 0.98), rgba(240, 208, 135, 0.18) 62%, transparent 78%);
  box-shadow: 0 0 0.8rem rgba(240, 208, 135, 0.38);
  animation-name: dustSpiral;
  animation-iteration-count: infinite;
}

.result-summary {
  position: relative;
  z-index: 1;
  display: flex;
  flex-wrap: wrap;
  gap: 0.7rem;
  margin-top: 1rem;
}

.result-summary__item {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  padding: 0.65rem 0.95rem;
  border-radius: 999px;
  background: rgba(255, 250, 242, 0.7);
  border: 1px solid rgba(202, 159, 72, 0.18);
  opacity: 0;
  transform: translateY(8px);
  animation: fadeSlide 0.5s ease forwards;
  animation-delay: var(--summary-delay, 0ms);
}

.result-summary__label { color: var(--ink-soft); letter-spacing: 0.18rem; font-size: 0.84rem; }
.result-summary__value { color: rgba(42, 29, 18, 0.94); }

.result-grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
  margin-top: 1.2rem;
}

.result-card {
  display: grid;
  gap: 1rem;
  align-content: start;
  padding: 1rem;
  border-radius: 1.35rem;
  background: linear-gradient(180deg, rgba(253, 250, 242, 0.9), rgba(246, 238, 220, 0.88));
  border: 1px solid rgba(129, 93, 57, 0.16);
  box-shadow: 0 1rem 2rem rgba(60, 40, 22, 0.08);
  opacity: 0;
  transform: translateY(18px) scale(0.98);
  animation: cardRise 0.7s ease forwards;
  animation-delay: var(--card-delay, 0ms);
}

.result-card__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}

.result-card__title { margin: 0; font-size: 0.9rem; color: var(--ink-soft); letter-spacing: 0.2rem; }
.result-card__name { margin: 0.35rem 0 0; font-family: var(--font-display); font-size: 1.45rem; letter-spacing: 0.1rem; }
.result-card__body { display: grid; gap: 0.95rem; }

.figure {
  display: grid;
  gap: 0.52rem;
  min-width: 7.2rem;
}

.figure__line {
  position: relative;
  height: 0.95rem;
  display: grid;
  align-items: center;
}

.figure__line.is-yin { grid-template-columns: 1fr 0.9rem 1fr; gap: 0.4rem; }
.figure__line.is-yang { grid-template-columns: 1fr; }
.figure__gap { width: 100%; height: 100%; }

.figure__stroke {
  display: block;
  width: 100%;
  height: 100%;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(190, 145, 63, 0.98), rgba(240, 208, 135, 0.96));
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.12), 0 0 1rem rgba(202, 159, 72, 0.18);
  transform: scaleX(0);
  transform-origin: left center;
  animation: lineReveal 0.7s cubic-bezier(0.2, 0.8, 0.2, 1) forwards;
  animation-delay: var(--delay, 0ms);
}

.figure__line.is-moving .figure__stroke {
  background: linear-gradient(90deg, rgba(232, 186, 76, 1), rgba(255, 226, 151, 1));
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.18), 0 0 1.2rem rgba(240, 208, 135, 0.52);
}

.scripture { display: grid; gap: 0.68rem; }
.scripture__title { margin: 0; font-size: 0.8rem; color: var(--ink-soft); letter-spacing: 0.2rem; }
.scripture__text { margin: 0; line-height: 1.8; color: rgba(27, 21, 16, 0.86); }

.gua-grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

.gua-card {
  border-radius: 1.2rem;
  border: 1px solid rgba(125, 91, 55, 0.16);
  background: linear-gradient(180deg, rgba(253, 249, 239, 0.9), rgba(247, 239, 221, 0.86));
  box-shadow: 0 1rem 2.2rem rgba(60, 40, 22, 0.08);
  overflow: hidden;
  transition: transform 0.36s ease, box-shadow 0.36s ease, border-color 0.36s ease;
  opacity: 0;
  transform: translateY(14px);
  animation: fadeSlide 0.55s ease forwards;
  animation-delay: var(--gua-delay, 0ms);
}

.gua-card:hover { transform: translateY(-4px); box-shadow: var(--shadow); }

.gua-card.is-current {
  border-color: rgba(202, 159, 72, 0.5);
  box-shadow: 0 1.1rem 2.4rem rgba(60, 40, 22, 0.1), 0 0 0 1px rgba(202, 159, 72, 0.14);
}

.gua-card__toggle {
  width: 100%;
  border: 0;
  background: transparent;
  color: inherit;
  text-align: left;
  cursor: pointer;
  padding: 1rem;
}

.gua-card__top {
  display: grid;
  grid-template-columns: auto auto 1fr;
  align-items: center;
  gap: 0.9rem;
}

.gua-card__index {
  width: 2.4rem;
  height: 2.4rem;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: rgba(202, 159, 72, 0.12);
  color: var(--gold);
  font-size: 0.9rem;
}

.gua-card__names { display: grid; gap: 0.2rem; }
.gua-card__title { margin: 0; font-family: var(--font-display); font-size: 1.35rem; letter-spacing: 0.08rem; }
.gua-card__subtitle { margin: 0; font-size: 0.94rem; color: var(--ink-soft); }

.gua-card__detail {
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows 0.46s ease;
}

.gua-card.is-open .gua-card__detail { grid-template-rows: 1fr; }

.gua-card__detail-inner {
  overflow: hidden;
  padding: 0 1rem 1rem;
  display: grid;
  gap: 0.9rem;
}

.gua-card__section {
  padding-top: 0.85rem;
  border-top: 1px solid rgba(112, 83, 47, 0.12);
}

.gua-card__section-title {
  margin: 0 0 0.5rem;
  color: var(--ink-soft);
  font-size: 0.82rem;
  letter-spacing: 0.18rem;
}

.yao-list { display: grid; gap: 0.38rem; }
.yao-list p, .gua-card__section p { margin: 0; line-height: 1.82; }

.reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 0.8s ease, transform 0.8s ease;
}

.reveal.is-visible { opacity: 1; transform: translateY(0); }

@keyframes mistFloat {
  0%, 100% { transform: translate3d(0, 0, 0) scale(1); }
  50% { transform: translate3d(1.4rem, -1rem, 0) scale(1.08); }
}

@keyframes mistDrift {
  0% { transform: translate3d(-1%, 0, 0); }
  100% { transform: translate3d(1%, -1%, 0); }
}

@keyframes washFloat {
  0%, 100% { transform: translate3d(0, 0, 0) scale(1); }
  50% { transform: translate3d(1rem, 1rem, 0) scale(1.06); }
}

@keyframes starBlink {
  0%, 100% { transform: scale(0.75); opacity: 0.22; }
  50% { transform: scale(1.08); opacity: 0.92; }
}

@keyframes floatSpark {
  0% { transform: translate3d(0, 0, 0) scale(0.6); opacity: 0; }
  18% { opacity: 0.7; }
  50% { transform: translate3d(0.8rem, -1.4rem, 0) scale(1); opacity: 1; }
  100% { transform: translate3d(-0.5rem, -3rem, 0) scale(0.5); opacity: 0; }
}

@keyframes sideMistFloat {
  0%, 100% { transform: translate3d(0, 0, 0) scale(1); }
  50% { transform: translate3d(0.9rem, -1.2rem, 0) scale(1.08); }
}

@keyframes sidePetalFall {
  0% { transform: translate3d(0, -1.6rem, 0) rotate(0deg) scale(0.78); opacity: 0; }
  12% { opacity: 0.84; }
  55% { transform: translate3d(1.1rem, 7rem, 0) rotate(126deg) scale(1); }
  100% { transform: translate3d(0.45rem, 16rem, 0) rotate(252deg) scale(0.76); opacity: 0; }
}

@keyframes sidePetalFallRight {
  0% { transform: translate3d(0, -1.6rem, 0) rotate(0deg) scale(0.78); opacity: 0; }
  12% { opacity: 0.84; }
  55% { transform: translate3d(-1.1rem, 7rem, 0) rotate(-126deg) scale(1); }
  100% { transform: translate3d(-0.45rem, 16rem, 0) rotate(-252deg) scale(0.76); opacity: 0; }
}

@keyframes sideSigilFloat {
  0%, 100% { translate: 0 0; opacity: 0.34; }
  50% { translate: 0 -0.75rem; opacity: 0.66; }
}

@keyframes rippleDrift {
  0%, 100% { transform: translateX(0) scaleX(0.96); opacity: 0.34; }
  50% { transform: translateX(0.5rem) scaleX(1.04); opacity: 0.82; }
}

@keyframes flameRise {
  0%, 100% { transform: translateY(0) scale(0.94); opacity: 0.58; }
  50% { transform: translateY(-0.7rem) scale(1.06); opacity: 0.98; }
}

@keyframes lightningFlash {
  0%, 100% { opacity: 0.18; transform: translateY(0) scaleY(0.94); }
  14% { opacity: 0.92; transform: translateY(-0.2rem) scaleY(1.06); }
  22% { opacity: 0.2; }
}

@keyframes windSweep {
  0%, 100% { transform: translateX(-1.1rem) scaleX(0.92); opacity: 0.24; }
  50% { transform: translateX(1rem) scaleX(1.08); opacity: 0.86; }
}

@keyframes dropFloat {
  0%, 100% { transform: translateY(0) scale(0.9); opacity: 0.3; }
  50% { transform: translateY(0.9rem) scale(1.08); opacity: 0.92; }
}

@keyframes mountainGlow {
  0%, 100% { filter: brightness(0.92); transform: translateY(0); }
  50% { filter: brightness(1.08); transform: translateY(-0.2rem); }
}

@keyframes dustSpiral {
  0% { transform: translate3d(0, 0.6rem, 0) scale(0.2); opacity: 0; }
  30% { opacity: 0.78; }
  100% { transform: translate3d(0, -3.6rem, 0) scale(1.15); opacity: 0; }
}

@keyframes spinSlow {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}

@keyframes pulseRing {
  0%, 100% { transform: translate(-50%, -50%) scale(0.98); opacity: 0.6; }
  50% { transform: translate(-50%, -50%) scale(1.03); opacity: 0.92; }
}

@keyframes resultPulse {
  0%, 100% { transform: translate(-50%, -50%) scale(0.96); opacity: 0.38; }
  50% { transform: translate(-50%, -50%) scale(1.04); opacity: 0.76; }
}

@keyframes sealBeat {
  0%, 100% { transform: rotate(-8deg) scale(1); }
  50% { transform: rotate(-6deg) scale(1.03); }
}

@keyframes lineReveal {
  from { transform: scaleX(0); opacity: 0.2; }
  to { transform: scaleX(1); opacity: 1; }
}

@keyframes fadeSlide {
  from { opacity: 0; transform: translateY(12px); }
  to { opacity: 1; transform: translateY(0); }
}

@keyframes cardRise {
  from { opacity: 0; transform: translateY(18px) scale(0.98); }
  to { opacity: 1; transform: translateY(0) scale(1); }
}

@keyframes revealCard {
  from { opacity: 0; transform: translateY(10px) scale(0.98); }
  to { opacity: 1; transform: translateY(0) scale(1); }
}

@keyframes revealUp {
  from {
    opacity: 0;
    transform: translateY(0.9rem) scale(0.98);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@keyframes castingAppear {
  0% { opacity: 0; transform: translate(-50%, -50%) scale(0.86); }
  20% { opacity: 1; transform: translate(-50%, -50%) scale(1); }
  80% { opacity: 1; transform: translate(-50%, -50%) scale(1.02); }
  100% { opacity: 0; transform: translate(-50%, -50%) scale(1.08); }
}

@keyframes evolutionWingLeft {
  0% { opacity: 0; transform: translateX(-14rem) scale(0.92) rotate(-5deg); }
  60% { opacity: 1; transform: translateX(1rem) scale(1.02) rotate(0deg); }
  100% { opacity: 1; transform: translateX(0) scale(1) rotate(0deg); }
}

@keyframes evolutionWingRight {
  0% { opacity: 0; transform: translateX(14rem) scale(0.92) rotate(5deg); }
  60% { opacity: 1; transform: translateX(-1rem) scale(1.02) rotate(0deg); }
  100% { opacity: 1; transform: translateX(0) scale(1) rotate(0deg); }
}

@keyframes evolutionStreamLeft {
  0% { opacity: 0; transform: translateX(-8rem) scaleX(0.2); }
  35% { opacity: 0.9; }
  100% { opacity: 0.2; transform: translateX(0) scaleX(1); }
}

@keyframes evolutionStreamRight {
  0% { opacity: 0; transform: translateX(8rem) scaleX(0.2); }
  35% { opacity: 0.9; }
  100% { opacity: 0.2; transform: translateX(0) scaleX(1); }
}

@keyframes evolutionBurst {
  0% { opacity: 0; transform: translate(-50%, -50%) scale(0.58); }
  45% { opacity: 0.92; transform: translate(-50%, -50%) scale(1.08); }
  100% { opacity: 0.34; transform: translate(-50%, -50%) scale(1); }
}

@keyframes evolutionFusionIn {
  0% { opacity: 0; transform: translateY(2rem) scale(0.86); }
  65% { opacity: 1; transform: translateY(-0.2rem) scale(1.02); }
  100% { opacity: 1; transform: translateY(0) scale(1); }
}

@keyframes gameRitualUpperIn {
  0% { opacity: 0; transform: translateX(-16rem) scale(0.9) rotate(-4deg); }
  60% { opacity: 1; transform: translateX(1rem) scale(1.02) rotate(0deg); }
  100% { opacity: 1; transform: translateX(0) scale(1) rotate(0deg); }
}

@keyframes gameRitualLowerIn {
  0% { opacity: 0; transform: translateX(16rem) scale(0.9) rotate(4deg); }
  60% { opacity: 1; transform: translateX(-1rem) scale(1.02) rotate(0deg); }
  100% { opacity: 1; transform: translateX(0) scale(1) rotate(0deg); }
}

@keyframes evolutionSealPulse {
  0% { opacity: 0; transform: scale(0.7); }
  55% { opacity: 1; transform: scale(1.08); }
  100% { opacity: 1; transform: scale(1); }
}

@keyframes evolutionFigureIn {
  0% { opacity: 0; transform: translateY(1.2rem) scale(0.92); }
  100% { opacity: 1; transform: translateY(0) scale(1); }
}

@keyframes evolutionNameIn {
  0% { opacity: 0; transform: translateY(1.6rem); letter-spacing: 0.42rem; }
  100% { opacity: 1; transform: translateY(0); letter-spacing: 0.08rem; }
}

@keyframes compassNodeIn {
  0% { opacity: 0; transform: translate(-50%, -50%) rotate(var(--angle)) translateY(calc(var(--radius) * -0.74)) rotate(calc(var(--angle) * -1)) scale(0.74); }
  100% { opacity: 1; transform: translate(-50%, -50%) rotate(var(--angle)) translateY(calc(var(--radius) * -1)) rotate(calc(var(--angle) * -1)) scale(1); }
}

@keyframes heroSceneDrift {
  0% { transform: translateX(0) translateY(0) scale(1); }
  50% { transform: translateX(1.4rem) translateY(-0.6rem) scale(1.04); }
  100% { transform: translateX(0) translateY(0) scale(1); }
}

@keyframes heroScenePulse {
  0% { transform: scale(0.96); opacity: 0.82; }
  50% { transform: scale(1.04); opacity: 1; }
  100% { transform: scale(0.96); opacity: 0.82; }
}

@keyframes heroWaterFlow {
  0% { transform: scaleX(0.94) translateX(0); opacity: 0.38; }
  45% { transform: scaleX(1.02) translateX(-0.15rem); opacity: 0.82; }
  100% { transform: scaleX(0.94) translateX(0.2rem); opacity: 0.38; }
}

@keyframes heroBirdArc {
  0% { transform: translateX(0) translateY(0); opacity: 0.18; }
  10% { opacity: 0.78; }
  50% { transform: translateX(-2.2rem) translateY(-0.8rem); opacity: 0.86; }
  100% { transform: translateX(-4.8rem) translateY(0.6rem); opacity: 0.18; }
}

@keyframes heroBranchSway {
  0% { transform: rotate(0deg); }
  50% { transform: rotate(1.6deg); }
  100% { transform: rotate(0deg); }
}

@keyframes heroSeasonFall {
  0% { transform: translate3d(0, 0, 0) rotate(0deg); opacity: 0; }
  10% { opacity: 0.84; }
  50% { transform: translate3d(2rem, 18rem, 0) rotate(140deg); }
  100% { transform: translate3d(-1.4rem, 36rem, 0) rotate(280deg); opacity: 0.08; }
}

@media (max-width: 1080px) {
  .screen-game-ritual__stage,
  .hero__inner { grid-template-columns: 1fr; }
  .hero__scene { min-height: 35rem; }
  .hero__painting { inset: 1rem 1rem 6.5rem; }
  .hero__legend { flex-direction: column; align-items: start; }
  .hero__legend-text { max-width: none; text-align: left; }
  .trigram-stage__panel,
  .game-lab__body,
  .daoyi-hall__body,
  .mingli-hall__body,
  .daoyi-reader-layout,
  .daoyi-detail-layout,
  .qi-scroll__body,
  .xiang-hall__body,
  .heluo-atlas__body,
  .mingli-report__main,
  .culture-hall__body,
  .academy__body,
  .season-compass__body,
  .study-trigram-detail__panel,
  .case-shelf__body,
  .scroll-reader__body,
  .academy-plus__row { grid-template-columns: 1fr; }
  .divination-insights,
  .result-grid,
  .gua-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .trigram-grid,
  .culture-nav,
  .study-nav,
  .study-trigrams__grid,
  .relation-map__graph { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .hexagram-flow__toolbar { grid-template-columns: 1fr; }
  .qi-scroll__season-nav,
  .qi-scroll__ribbon,
  .qi-scroll__track { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .qi-scroll__track { grid-template-rows: repeat(12, auto); }
  .hexagram-flow__preview { grid-template-columns: repeat(4, minmax(0, 1fr)); }
  .screen-evolution__arena,
  .screen-castflow__body { grid-template-columns: 1fr; }
  .screen-evolution__matrix { grid-template-columns: repeat(4, minmax(0, 1fr)); }
  .timing-panel__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .method-panel { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .screen-result__list { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .case-panel__figures { grid-template-columns: 1fr; }
  .body-use__orbit { grid-template-columns: 1fr; }
  .body-use__orbit::before { display: none; }
  .daoyi-rail { position: static; }
  .game-form__builder,
  .game-form__identify,
  .game-hexagram-name,
  .game-reflect__board,
  .game-rise__body,
  .game-compose__slots { grid-template-columns: 1fr; }
  .game-form__plaque { grid-row: auto; }
  .game-form__choices,
  .game-scene__choices,
  .game-map__grid,
  .game-hexagram-name__choices,
  .game-reflect__choices { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .screen-game-ritual__stage { min-height: auto; }
  .screen-game-ritual__wing,
  .screen-game-ritual__core { min-height: 13.5rem; }
  .relation-node--base,
  .relation-node--mutual,
  .relation-node--reverse,
  .relation-node--changed,
  .relation-node--opposite { grid-column: auto; grid-row: auto; }
}

@media (max-width: 720px) {
  .shell { width: min(100% - 1rem, 1320px); }
  .result-grid,
  .trigram-grid,
  .gua-grid,
  .divination-insights,
  .method-panel,
  .study-nav,
  .study-trigrams__grid,
  .relation-map__graph,
  .timing-panel__grid { grid-template-columns: 1fr; }
  .hexagram-flow__preview { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .screen-result__list { grid-template-columns: 1fr; }
  .topbar { padding-inline: 0.9rem; }
  .hero,
  .panel,
  .trigram-showcase,
  .season-compass,
  .daoyi-hall,
  .mingli-hall,
  .qi-scroll,
  .xiang-hall,
  .heluo-atlas,
  .culture-hall,
  .hexagram-flow,
  .game-lab,
  .academy,
  .hall { border-radius: 1.2rem; }
  .hero__inner,
  .trigram-showcase,
  .season-compass,
  .daoyi-hall,
  .mingli-hall,
  .qi-scroll,
  .xiang-hall,
  .heluo-atlas,
  .culture-hall,
  .hexagram-flow,
  .game-lab,
  .academy,
  .panel,
  .hall { padding-inline: 1rem; }
  .hero__scroll { padding: 1.2rem; }
  .hero__scroll-head { flex-direction: column; }
  .hero__title { font-size: clamp(2.2rem, 11vw, 3.6rem); }
  .hero__switch { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .hero__scene { order: -1; min-height: 23rem; padding: 0.7rem; }
  .hero__painting { inset: 0.7rem 0.7rem 5.8rem; }
  .hero__branch { width: 55%; height: 34%; }
  .hero__sun { width: 6rem; }
  .hero__legend { left: 0.7rem; right: 0.7rem; bottom: 0.7rem; padding: 0.85rem 0.95rem; gap: 0.35rem; }
  .hero__legend-text { text-align: left; }
  .hero__menu { gap: 0.55rem; }
  .hero__link { min-width: calc(50% - 0.3rem); }
  .daoyi-hall__heading,
  .daoyi-overview__header,
  .daoyi-reader__header,
  .daoyi-detail__header { align-items: start; }
  .daoyi-rail,
  .daoyi-reader,
  .daoyi-detail { padding: 0.95rem; }
  .daoyi-chapter-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); max-height: none; }
  .daoyi-detail__chapters { grid-template-columns: 1fr; }
  .qi-scroll__aside,
  .qi-scroll__canvas,
  .qi-scroll__detail-card { padding: 0.95rem; }
  .qi-scroll__season-nav,
  .qi-scroll__ribbon,
  .qi-scroll__message-grid,
  .qi-scroll__track { grid-template-columns: 1fr; }
  .qi-scroll__track {
    grid-template-rows: none;
    grid-auto-flow: row;
    gap: 0.8rem;
  }
  .qi-scroll__detail-head { flex-direction: column; align-items: start; }
  .qi-scroll__detail-wings,
  .qi-scroll__blocks,
  .qi-scroll__metrics { grid-template-columns: 1fr; }
  .game-lab__body { gap: 1rem; }
  .game-scroll,
  .game-board { padding: 1rem; }
  .screen-game-ritual__inner { padding: 1rem 0.9rem 1.2rem; }
  .screen-game-ritual__header { gap: 0.4rem; }
  .screen-game-ritual__narrative { min-height: 8.4rem; }
  .screen-game-ritual__title { font-size: clamp(2rem, 9vw, 3rem); }
  .screen-game-ritual__stage { gap: 0.8rem; }
  .screen-game-ritual__wing,
  .screen-game-ritual__core { min-height: 11rem; padding: 0.85rem; }
  .screen-game-ritual__scene-card--upper { left: 10%; }
  .screen-game-ritual__scene-card--lower { right: 10%; }
  .screen-game-ritual__scene-symbols { display: none; }
  .game-board__head,
  .game-board__footer { flex-direction: column; }
  .game-board__progress,
  .game-reward { width: 100%; min-width: 0; }
  .game-board__stats { grid-template-columns: 1fr; }
  .game-yinyang { grid-template-columns: 1fr; }
  .game-form__builder,
  .game-form__identify,
  .game-hexagram-name,
  .game-reflect__board,
  .game-rise__body,
  .game-compose__slots { grid-template-columns: 1fr; }
  .game-form__plaque { grid-row: auto; }
  .game-form__choices,
  .game-scene__choices,
  .game-map__grid,
  .game-hexagram-name__choices,
  .game-reflect__choices { grid-template-columns: 1fr; }
  .game-compose,
  .game-hexagram-name,
  .game-reflect,
  .game-rise { padding: 0.4rem 0; }
  .game-compose__palette .game-bagua-token,
  .game-rise__tokens .game-bagua-token,
  .game-rise__confirm,
  .game-compose__confirm,
  .game-reflect__button { width: 100%; }
  .game-rise__selector,
  .game-compose__slot,
  .game-compose__preview,
  .game-reflect__card,
  .game-reflect__mirror { min-height: auto; }
  .game-yinyang__zone { min-height: 7.5rem; align-content: center; }
  .game-yinyang__zone::after { top: 50%; translate: -50% -50%; width: 5rem; height: 5rem; }
  .game-yinyang__mirror { min-height: 18rem; }
  .game-yinyang__actions,
  .game-board__actions { flex-direction: column; }
  .game-yinyang__action,
  .game-board__actions .panel__button { width: 100%; }
  .game-card { width: min(100%, 100%); min-height: 11.5rem; }
  .game-map__palette { display: grid; grid-template-columns: 1fr; }
  .game-bagua-token,
  .game-map__confirm { width: 100%; }
  .game-certificate__seal { position: static; margin-bottom: 0.8rem; }
  .game-certificate__foot { flex-direction: column; }
  .trigram-stage__scene { min-height: 18rem; }
  .trigram-stage__copy { gap: 0.75rem; }
  .trigram-stage__figure .figure { min-width: 9rem; }
  .study-panel__header,
  .study-trigram__head,
  .trigram-showcase__heading,
  .season-compass__heading,
  .xiang-hall__heading,
  .heluo-atlas__heading,
  .culture-hall__heading,
  .hexagram-flow__heading,
  .academy__heading { align-items: start; }
  .xiang-panel__header,
  .xiang-panel__hero,
  .xiang-panel__blocks { grid-template-columns: 1fr; }
  .xiang-panel__header { flex-direction: column; align-items: start; }
  .xiang-panel__metrics { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .xiang-items { grid-template-columns: 1fr; }
  .study-panel__header,
  .study-trigram__head { flex-direction: column; }
  .culture-panel__header { flex-direction: column; align-items: start; }
  .culture-panel__metrics,
  .culture-panel__cards,
  .culture-panel__shelf-grid { grid-template-columns: 1fr; }
  .study-panel__body { max-height: none; padding-right: 0; }
  .study-trigram-detail__visual { min-height: 11rem; }
  .case-shelf__body,
  .scroll-reader__body,
  .academy-plus__row { gap: 1rem; }
  .season-compass__stage { min-height: 26rem; }
  .season-compass__wheel { width: min(100%, 21rem); }
  .season-compass__node { --radius: 8.8rem; width: 5.2rem; }
  .hexagram-flow__figure .figure { min-width: 8.5rem; }
  .screen-evolution__inner { padding: 0.95rem; }
  .screen-evolution__topbar { flex-direction: column; align-items: start; }
  .screen-evolution__arena { padding: 1rem; gap: 1rem; }
  .screen-evolution__wing,
  .screen-evolution__fusion { min-height: auto; }
  .screen-evolution__visual,
  .trigram-visual--evolution { min-height: 11rem; }
  .screen-evolution__matrix { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .screen-evolution__hexagram-figure .figure { min-width: 10rem; }
  .screen-evolution__hexagram-name { font-size: clamp(1.9rem, 7vw, 2.8rem); }
  .screen-castflow__inner { width: min(100vw - 0.8rem, 1280px); height: min(100vh - 0.8rem, 860px); padding: 0.8rem; }
  .screen-castflow__topbar { flex-direction: column; }
  .screen-castflow__body { grid-template-columns: 1fr; }
  .screen-castflow__stage { min-height: 32rem; }
  .screen-castflow__assembly { inset: 10rem 1.6rem 6.8rem; }
  .castflow-line.is-yang,
  .castflow-line.is-yin { width: min(100%, 14rem); }
  .screen-castflow__rail { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .cast-flow-entry { flex-direction: column; align-items: start; }
  .body-use__panel,
  .relation-map__current,
  .relation-map__graph,
  .relation-map__detail { margin-inline: 0.9rem; }
  .bagua-orbit__char:nth-child(1) { transform: rotate(0deg) translateY(-10.9rem) rotate(0deg); }
  .bagua-orbit__char:nth-child(2) { transform: rotate(45deg) translateY(-10.9rem) rotate(-45deg); }
  .bagua-orbit__char:nth-child(3) { transform: rotate(90deg) translateY(-10.9rem) rotate(-90deg); }
  .bagua-orbit__char:nth-child(4) { transform: rotate(135deg) translateY(-10.9rem) rotate(-135deg); }
  .bagua-orbit__char:nth-child(5) { transform: rotate(180deg) translateY(-10.9rem) rotate(-180deg); }
  .bagua-orbit__char:nth-child(6) { transform: rotate(225deg) translateY(-10.9rem) rotate(-225deg); }
  .bagua-orbit__char:nth-child(7) { transform: rotate(270deg) translateY(-10.9rem) rotate(-270deg); }
  .bagua-orbit__char:nth-child(8) { transform: rotate(315deg) translateY(-10.9rem) rotate(-315deg); }
}

.oracle {
  position: relative;
  padding: 2.1rem 2.2rem 2.4rem;
  border-radius: 2rem;
  background:
    radial-gradient(circle at 14% 18%, rgba(255, 250, 240, 0.76), transparent 28%),
    radial-gradient(circle at 82% 20%, rgba(240, 208, 135, 0.16), transparent 24%),
    linear-gradient(180deg, rgba(251, 246, 235, 0.92), rgba(244, 234, 212, 0.88));
  box-shadow: var(--shadow);
  overflow: hidden;
}

.oracle::before,
.oracle::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.oracle::before {
  background:
    linear-gradient(135deg, rgba(240, 208, 135, 0.08), transparent 30%),
    linear-gradient(-135deg, rgba(157, 47, 32, 0.08), transparent 28%);
}

.oracle::after {
  background:
    radial-gradient(circle at 50% -10%, rgba(255, 255, 255, 0.48), transparent 34%),
    radial-gradient(circle at 50% 115%, rgba(202, 159, 72, 0.18), transparent 26%);
  opacity: 0.82;
}

.oracle__head,
.oracle__body,
.oracle-catalog {
  position: relative;
  z-index: 1;
}

.oracle__heading {
  display: flex;
  align-items: center;
  gap: 1rem;
}

.oracle__seal {
  width: 4rem;
  height: 4rem;
  display: grid;
  place-items: center;
  border-radius: 50%;
  border: 1px solid rgba(157, 47, 32, 0.18);
  color: var(--vermillion);
  font-family: var(--font-display);
  font-size: 1.8rem;
  background: linear-gradient(180deg, rgba(255, 248, 237, 0.9), rgba(248, 238, 214, 0.72));
  box-shadow: inset 0 0 0 0.26rem rgba(157, 47, 32, 0.05);
}

.oracle__label,
.oracle-catalog__label,
.oracle-result__label {
  margin: 0;
  color: var(--ink-soft);
  letter-spacing: 0.22rem;
  font-size: 0.86rem;
}

.oracle__title,
.oracle-catalog__title,
.oracle-result__title {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(2rem, 3.4vw, 2.9rem);
}

.oracle__body {
  margin-top: 1.4rem;
  display: grid;
  grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.05fr);
  gap: 1.3rem;
}

.oracle-ritual,
.oracle-result,
.oracle-catalog {
  border-radius: 1.8rem;
  border: 1px solid rgba(215, 187, 135, 0.42);
  background: linear-gradient(180deg, rgba(255, 251, 242, 0.72), rgba(247, 238, 218, 0.6));
  box-shadow: 0 1.2rem 2.6rem rgba(102, 72, 29, 0.08);
}

.oracle-ritual {
  padding: 1.15rem;
  display: grid;
  gap: 1rem;
}

.oracle-ritual__field textarea {
  min-height: 6.4rem;
}

.oracle-ritual__actions {
  display: flex;
  justify-content: center;
}

.oracle-stage {
  position: relative;
  min-height: 31rem;
  border-radius: 1.55rem;
  overflow: hidden;
  background:
    radial-gradient(circle at 50% 20%, rgba(255, 249, 236, 0.8), transparent 26%),
    radial-gradient(circle at 18% 16%, rgba(255, 255, 255, 0.36), transparent 20%),
    radial-gradient(circle at 82% 20%, rgba(240, 208, 135, 0.16), transparent 20%),
    linear-gradient(180deg, rgba(247, 239, 222, 0.82), rgba(241, 225, 191, 0.7));
  border: 1px solid rgba(218, 190, 141, 0.36);
}

.oracle-stage__mist,
.oracle-stage__halo {
  position: absolute;
  pointer-events: none;
}

.oracle-stage__mist {
  width: 16rem;
  height: 16rem;
  border-radius: 50%;
  filter: blur(22px);
  opacity: 0.75;
}

.oracle-stage__mist--a {
  left: -10%;
  top: 8%;
  background: radial-gradient(circle, rgba(255, 255, 255, 0.36), transparent 72%);
  animation: washFloat 14s ease-in-out infinite;
}

.oracle-stage__mist--b {
  right: -12%;
  bottom: 6%;
  background: radial-gradient(circle, rgba(240, 208, 135, 0.32), transparent 72%);
  animation: washFloat 16s ease-in-out infinite reverse;
}

.oracle-stage__halo {
  left: 50%;
  top: 40%;
  width: 20rem;
  height: 20rem;
  border-radius: 50%;
  background:
    radial-gradient(circle, rgba(255, 243, 214, 0.52), transparent 56%),
    radial-gradient(circle, rgba(240, 208, 135, 0.16), transparent 74%);
  transform: translate(-50%, -50%);
  animation: lotGlow 4.8s ease-in-out infinite;
}

.oracle-stage__dust {
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.oracle-stage__spark {
  position: absolute;
  left: var(--x);
  top: var(--y);
  width: var(--size);
  height: var(--size);
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255, 246, 225, 0.96), rgba(240, 208, 135, 0.3) 62%, transparent 78%);
  box-shadow: 0 0 0.8rem rgba(240, 208, 135, 0.36);
  animation: lotSparkRise var(--duration) ease-in-out infinite;
  animation-delay: var(--delay);
}

.oracle-stage__tube {
  position: absolute;
  left: 50%;
  bottom: 2rem;
  width: min(18.6rem, 74%);
  height: 14.8rem;
  translate: -50% 0;
  border-radius: 3rem 3rem 2.2rem 2.2rem;
  background:
    radial-gradient(circle at 30% 18%, rgba(255, 255, 255, 0.22), transparent 26%),
    linear-gradient(180deg, rgba(164, 55, 39, 0.96), rgba(111, 24, 18, 0.98));
  box-shadow:
    inset 0 -1.6rem 2rem rgba(66, 13, 10, 0.26),
    0 1.8rem 3rem rgba(90, 24, 18, 0.24);
}

.oracle-stage__mouth {
  position: absolute;
  left: 50%;
  top: -1rem;
  width: 92%;
  height: 2.4rem;
  translate: -50% 0;
  border-radius: 999px;
  background:
    radial-gradient(circle at 50% 30%, rgba(255, 255, 255, 0.24), transparent 48%),
    linear-gradient(180deg, rgba(123, 25, 17, 0.98), rgba(88, 16, 11, 1));
  box-shadow: inset 0 0.16rem 0 rgba(255, 255, 255, 0.08);
}

.oracle-stage__sticks {
  position: absolute;
  left: 50%;
  bottom: 5.2rem;
  width: min(18rem, 80%);
  height: 18rem;
  translate: -50% 0;
}

.oracle-stage__stick {
  position: absolute;
  left: 50%;
  bottom: 0;
  width: 0.86rem;
  height: var(--stick-height);
  border-radius: 999px;
  background: linear-gradient(180deg, rgba(250, 223, 161, 0.96), rgba(198, 145, 51, 0.96));
  transform: translateX(var(--stick-offset)) rotate(var(--stick-rotate));
  transform-origin: bottom center;
  box-shadow: 0 0.4rem 0.8rem rgba(178, 130, 44, 0.2);
  animation: lotStickFloat 6.4s ease-in-out infinite;
  animation-delay: var(--stick-delay);
}

.oracle-stage__stick::before {
  content: "";
  position: absolute;
  inset: 0.5rem 0.16rem auto;
  height: 1.9rem;
  border-radius: 999px;
  background: linear-gradient(180deg, rgba(135, 25, 18, 0.98), rgba(96, 17, 12, 0.98));
}

.oracle-stage__stick::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 3rem;
  width: 0.2rem;
  height: calc(100% - 4rem);
  translate: -50% 0;
  background: rgba(255, 243, 214, 0.28);
}

.oracle-stage__seal-mark {
  position: absolute;
  left: 50%;
  bottom: 2.35rem;
  translate: -50% 0;
  padding: 0.55rem 1.5rem;
  border-radius: 999px;
  border: 1px solid rgba(255, 238, 213, 0.14);
  background: rgba(91, 15, 12, 0.32);
  color: rgba(255, 238, 213, 0.9);
  font-family: var(--font-display);
  letter-spacing: 0.22rem;
}

.oracle-stage__slip {
  position: absolute;
  left: 50%;
  bottom: 5.8rem;
  width: min(8.6rem, 38vw);
  min-height: 10.8rem;
  padding: 1rem 0.8rem 1.2rem;
  display: grid;
  justify-items: center;
  align-content: start;
  gap: 0.45rem;
  border-radius: 1.3rem;
  background:
    linear-gradient(180deg, rgba(255, 252, 246, 0.98), rgba(250, 240, 214, 0.96));
  border: 1px solid rgba(214, 183, 121, 0.7);
  box-shadow: 0 0.9rem 2rem rgba(108, 73, 28, 0.18);
  transition: transform 0.78s ease, box-shadow 0.78s ease, opacity 0.5s ease;
  transform: translate(-50%, 0) rotate(-1deg);
}

.oracle-stage__slip::before,
.oracle-stage__slip::after {
  content: "";
  position: absolute;
  inset: 0.8rem auto 0.8rem 0.85rem;
  width: 0.16rem;
  background: linear-gradient(180deg, rgba(202, 159, 72, 0.12), rgba(202, 159, 72, 0.36), rgba(202, 159, 72, 0.12));
}

.oracle-stage__slip::after {
  inset: 0.8rem 0.85rem 0.8rem auto;
}

.oracle-stage__slip-no {
  margin-top: 0.2rem;
  font-family: var(--font-display);
  font-size: 1.3rem;
  color: var(--ink);
}

.oracle-stage__slip-mark {
  font-size: 0.9rem;
  letter-spacing: 0.18rem;
  color: var(--vermillion);
}

.oracle-stage__slip-meta {
  font-size: 0.82rem;
  color: var(--ink-soft);
}

.oracle-stage[data-mode="idle"] .oracle-stage__slip {
  transform: translate(-50%, 1.6rem) rotate(-1deg) scale(0.92);
  opacity: 0.88;
}

.oracle-stage[data-mode="drawing"] .oracle-stage__slip {
  animation: lotSlipLift 1.2s cubic-bezier(0.22, 0.74, 0.19, 1) forwards;
}

.oracle-stage[data-mode="reveal"] .oracle-stage__slip {
  transform: translate(-50%, -12.8rem) rotate(-8deg) scale(1.02);
  box-shadow: 0 1.8rem 2.8rem rgba(111, 74, 24, 0.26);
}

.oracle-stage[data-mode="drawing"] .oracle-stage__tube,
.oracle-stage[data-mode="reveal"] .oracle-stage__tube {
  box-shadow:
    inset 0 -1.6rem 2rem rgba(66, 13, 10, 0.26),
    0 1.8rem 3rem rgba(90, 24, 18, 0.3),
    0 0 2.2rem rgba(202, 159, 72, 0.18);
}

.oracle-result {
  padding: 1.2rem;
}

.oracle-result__card {
  display: grid;
  gap: 1rem;
}

.oracle-result__head {
  display: flex;
  align-items: start;
  gap: 1rem;
}

.oracle-result__seal {
  width: 4.4rem;
  height: 4.4rem;
  display: grid;
  place-items: center;
  border-radius: 1.3rem;
  background: linear-gradient(180deg, rgba(168, 50, 35, 0.96), rgba(112, 22, 16, 0.98));
  color: #fdf3df;
  font-family: var(--font-display);
  font-size: 1.7rem;
  box-shadow: 0 1rem 1.8rem rgba(109, 28, 19, 0.22);
}

.oracle-result__titles {
  display: grid;
  gap: 0.25rem;
}

.oracle-result__question {
  margin: 0;
  color: var(--ink-soft);
  font-size: 0.94rem;
  line-height: 1.8;
}

.oracle-result__subtitle {
  margin: 0;
  color: rgba(141, 87, 18, 0.88);
  font-family: var(--font-display);
  font-size: 1.15rem;
}

.oracle-result__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
}

.oracle-result__tag {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.2rem;
  padding: 0.35rem 0.85rem;
  border-radius: 999px;
  border: 1px solid rgba(212, 183, 121, 0.44);
  background: rgba(255, 248, 233, 0.82);
  color: var(--ink-soft);
  font-size: 0.86rem;
}

.oracle-result__tag.is-auspicious {
  background: rgba(202, 159, 72, 0.16);
  color: #7c5410;
}

.oracle-result__tag.is-caution {
  background: rgba(157, 47, 32, 0.1);
  color: #8b3628;
}

.oracle-result__body {
  display: grid;
  max-height: 31rem;
  overflow: auto;
  padding-right: 0.3rem;
}

.oracle-result__layout {
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(18rem, 0.92fr);
  gap: 0.9rem;
}

.oracle-result__column {
  display: grid;
  gap: 0.85rem;
  align-content: start;
}

.oracle-result__section {
  padding: 1rem 1.05rem;
  border-radius: 1.3rem;
  background: rgba(255, 252, 245, 0.7);
  border: 1px solid rgba(223, 196, 147, 0.34);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.28);
  opacity: 0;
  transform: translateY(0.6rem);
  animation: revealUp 0.6s ease forwards;
  animation-delay: var(--lot-section-delay, 0ms);
}

.oracle-result__section--omens {
  background:
    radial-gradient(circle at 85% 18%, rgba(240, 208, 135, 0.14), transparent 18%),
    rgba(255, 252, 245, 0.76);
}

.oracle-result__section--verse {
  background:
    radial-gradient(circle at 50% 0%, rgba(240, 208, 135, 0.12), transparent 28%),
    rgba(255, 252, 245, 0.74);
}

.oracle-result__section--story {
  background:
    linear-gradient(180deg, rgba(255, 252, 245, 0.78), rgba(250, 242, 226, 0.72));
}

.oracle-result__section-title {
  margin: 0 0 0.7rem;
  font-family: var(--font-display);
  font-size: 1.28rem;
}

.oracle-result__text {
  margin: 0;
  color: var(--ink-soft);
  line-height: 1.95;
}

.oracle-result__text--verse {
  text-align: center;
  letter-spacing: 0.08rem;
}

.oracle-result__text--story {
  text-align: left;
}

.oracle-result__omens {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.55rem;
}

.oracle-result__omen {
  display: grid;
  gap: 0.15rem;
  padding: 0.7rem 0.75rem;
  border-radius: 0.95rem;
  border: 1px solid rgba(212, 183, 121, 0.26);
  background: rgba(255, 247, 231, 0.9);
}

.oracle-result__omen-label {
  color: var(--ink-soft);
  font-size: 0.78rem;
  letter-spacing: 0.1rem;
}

.oracle-result__omen-value {
  color: var(--ink);
  font-family: var(--font-display);
  font-size: 1rem;
}

.oracle-catalog {
  margin-top: 1.35rem;
  padding: 1.2rem;
}

.oracle-catalog__head {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1rem;
}

.oracle-catalog__title {
  font-size: clamp(1.65rem, 2.5vw, 2.1rem);
}

.oracle-catalog__grid {
  display: grid;
  grid-template-columns: repeat(10, minmax(0, 1fr));
  gap: 0.6rem;
}

.oracle-catalog__button {
  position: relative;
  min-height: 4.25rem;
  padding: 0.7rem 0.45rem;
  display: grid;
  gap: 0.25rem;
  justify-items: center;
  border-radius: 1rem;
  border: 1px solid rgba(212, 183, 121, 0.34);
  background: linear-gradient(180deg, rgba(255, 251, 243, 0.9), rgba(247, 238, 214, 0.76));
  color: var(--ink);
  box-shadow: 0 0.7rem 1.4rem rgba(102, 72, 29, 0.08);
  cursor: pointer;
  transition: transform 0.24s ease, border-color 0.24s ease, box-shadow 0.24s ease;
  opacity: 0;
  transform: translateY(0.4rem);
  animation: revealUp 0.45s ease forwards;
  animation-delay: var(--lot-delay, 0ms);
}

.oracle-catalog__button:hover {
  transform: translateY(-0.18rem);
  border-color: rgba(202, 159, 72, 0.66);
  box-shadow: 0 1rem 1.8rem rgba(102, 72, 29, 0.12);
}

.oracle-catalog__button.is-active {
  border-color: rgba(157, 47, 32, 0.46);
  background: linear-gradient(180deg, rgba(255, 245, 227, 0.94), rgba(244, 230, 195, 0.84));
  box-shadow: 0 1rem 2rem rgba(123, 42, 28, 0.14);
}

.oracle-catalog__button.is-auspicious .oracle-catalog__fortune { color: #7b5514; }
.oracle-catalog__button.is-caution .oracle-catalog__fortune { color: #8f3727; }

.oracle-catalog__number {
  font-family: var(--font-display);
  font-size: 1.14rem;
}

.oracle-catalog__fortune {
  font-size: 0.73rem;
  color: var(--ink-soft);
}

@keyframes lotSlipLift {
  0% {
    transform: translate(-50%, 2rem) rotate(-2deg) scale(0.88);
    opacity: 0.3;
  }
  22% {
    transform: translate(-50%, -1.8rem) rotate(4deg) scale(0.96);
    opacity: 1;
  }
  58% {
    transform: translate(-50%, -10rem) rotate(-10deg) scale(1.02);
  }
  100% {
    transform: translate(-50%, -12.8rem) rotate(-8deg) scale(1.02);
  }
}

@keyframes lotGlow {
  0%, 100% { transform: translate(-50%, -50%) scale(0.92); opacity: 0.6; }
  50% { transform: translate(-50%, -50%) scale(1.06); opacity: 0.95; }
}

@keyframes lotSparkRise {
  0% {
    transform: translate3d(0, 0.8rem, 0) scale(0.8);
    opacity: 0;
  }
  18% {
    opacity: 1;
  }
  100% {
    transform: translate3d(0, -2rem, 0) scale(1.05);
    opacity: 0;
  }
}

@keyframes lotStickFloat {
  0%, 100% { transform: translateX(var(--stick-offset)) rotate(var(--stick-rotate)); }
  50% { transform: translateX(var(--stick-offset)) translateY(-0.4rem) rotate(calc(var(--stick-rotate) + 1.6deg)); }
}

@keyframes certificateMistDrift {
  0%, 100% { transform: translate3d(0, 0, 0) scale(0.94); opacity: 0.34; }
  50% { transform: translate3d(1.4rem, -1.1rem, 0) scale(1.06); opacity: 0.48; }
}

@keyframes certificateVeilSpin {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}

@keyframes certificateSealPulse {
  0%, 100% { transform: rotate(-10deg) scale(0.98); box-shadow: 0 1.1rem 2.2rem rgba(83, 25, 17, 0.28), inset 0 0 0 0.35rem rgba(255, 247, 230, 0.08); }
  50% { transform: rotate(-7deg) scale(1.03); box-shadow: 0 1.4rem 2.8rem rgba(83, 25, 17, 0.34), inset 0 0 0 0.35rem rgba(255, 247, 230, 0.12); }
}

@keyframes certificateRailReveal {
  from { opacity: 0; transform: translateX(-1.1rem); }
  to { opacity: 1; transform: translateX(0); }
}

@keyframes certificateStageIn {
  from { opacity: 0; transform: translateX(-0.8rem); }
  to { opacity: 1; transform: translateX(0); }
}

@keyframes certificateScrollUnfurl {
  0% { opacity: 0; transform: translateY(1.6rem) scaleY(0.88); filter: saturate(0.84); }
  55% { opacity: 1; }
  100% { opacity: 1; transform: translateY(0) scaleY(1); filter: saturate(1); }
}

@keyframes certificateColumnReveal {
  from { opacity: 0; transform: translateY(1rem); }
  to { opacity: 1; transform: translateY(0); }
}

@media (max-width: 1120px) {
  .oracle__body { grid-template-columns: 1fr; }
  .oracle-catalog__grid { grid-template-columns: repeat(5, minmax(0, 1fr)); }
  .oracle-result__layout { grid-template-columns: 1fr; }
  .game-questionlab__layout--split,
  .game-questionlab__layout--time,
  .game-questionlab__layout--poster,
  .screen-game-certificate__frame { grid-template-columns: 1fr; }
  .screen-game-certificate__inner { height: min(100vh - 1rem, 940px); }
  .screen-game-certificate__frame {
    height: min(100%, 860px);
    padding-left: 0;
  }
  .screen-game-certificate__rail {
    position: static;
    width: auto;
    grid-auto-flow: column;
    grid-auto-columns: minmax(96px, 1fr);
    overflow-x: auto;
    align-content: initial;
    justify-items: initial;
    padding: 0 0 0.5rem;
  }
  .screen-game-certificate__rail::before,
  .screen-game-certificate__rail::after { display: none; }
  .screen-game-certificate__scroll { height: calc(100% - 4.2rem); }
  .screen-game-certificate__columns { grid-template-columns: 1.1fr 1fr 1fr 1.2fr 0.92fr; }
}

@media (max-width: 720px) {
  .oracle { padding: 1.1rem 1rem 1.3rem; }
  .oracle__heading,
  .oracle-catalog__head,
  .oracle-result__head { align-items: start; }
  .oracle-catalog__head,
  .oracle-result__head { flex-direction: column; }
  .oracle-stage { min-height: 26rem; }
  .oracle-stage__tube { width: min(16rem, 82%); height: 13rem; }
  .oracle-stage__sticks { bottom: 4.6rem; }
  .oracle-stage[data-mode="reveal"] .oracle-stage__slip { transform: translate(-50%, -10.2rem) rotate(-8deg) scale(1); }
  .oracle-catalog__grid { grid-template-columns: repeat(4, minmax(0, 1fr)); }
  .oracle-result__omens { grid-template-columns: 1fr; }
  .game-questionlab__bins,
  .game-questionlab__gates,
  .game-questionlab__times,
  .game-questionlab__segments,
  .game-questionlab__cards { grid-template-columns: 1fr; }
  .game-cast__shichen-grid,
  .game-cast__chip-grid,
  .game-cast__token-grid,
  .game-cast__line-grid,
  .game-cast__poster-figures { grid-template-columns: 1fr; }
  .game-questionlab--cast .game-questionlab__layout--poster { grid-template-columns: 1fr; }
  .game-questionlab__head,
  .game-questionlab__panel,
  .game-questionlab__poster-card { padding: 0.95rem; }
  .screen-game-certificate { padding: 0.55rem; }
  .screen-game-certificate__inner { height: min(100vh - 0.6rem, 1000px); }
  .screen-game-certificate__close {
    top: 0;
    right: 0;
    min-width: auto;
    padding: 0.72rem 0.96rem;
  }
  .screen-game-certificate__seal {
    right: 3.4rem;
    top: 1.8rem;
    width: 4.8rem;
    font-size: 1.8rem;
  }
  .screen-game-certificate__scroll {
    padding: 2.3rem 1rem 2.1rem;
    border-radius: 2rem;
    height: calc(100% - 4.4rem);
  }
  .screen-game-certificate__scroll-edge {
    left: 1.2rem;
    right: 1.2rem;
  }
  .screen-game-certificate__paper {
    padding: 1.25rem 0.9rem 1.35rem;
  }
  .screen-game-certificate__columns {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    grid-auto-rows: minmax(240px, auto);
    gap: 0.5rem;
  }
  .screen-game-certificate__column {
    min-height: 240px;
    padding: 0.8rem 0.25rem;
    gap: 0.75rem;
    border-right: none;
  }
  .screen-game-certificate__column--title .screen-game-certificate__column-text {
    font-size: 1.72rem;
  }
  .screen-game-certificate__column-text {
    font-size: 1rem;
    line-height: 1.84;
  }
  .screen-game-certificate__column-label {
    font-size: 0.8rem;
    letter-spacing: 0.12rem;
    padding: 0.18rem 0.42rem;
  }
}

body.is-mobile-ui .hero,
body.is-mobile-ui .panel,
body.is-mobile-ui .trigram-showcase,
body.is-mobile-ui .season-compass,
body.is-mobile-ui .daoyi-hall,
body.is-mobile-ui .qi-scroll,
body.is-mobile-ui .xiang-hall,
body.is-mobile-ui .heluo-atlas,
body.is-mobile-ui .culture-hall,
body.is-mobile-ui .hexagram-flow,
body.is-mobile-ui .game-lab,
body.is-mobile-ui .academy,
body.is-mobile-ui .hall,
body.is-mobile-ui .oracle {
  border-radius: 1.35rem;
  box-shadow: 0 14px 28px rgba(53, 34, 16, 0.09);
}

body.is-mobile-ui .sky-effects__edge,
body.is-mobile-ui .sky-effects__stars,
body.is-mobile-ui .hero__particles {
  display: none;
}

body.is-mobile-ui .hero__menu {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

body.is-mobile-ui .hero__inner {
  grid-template-columns: 1fr;
}

body.is-mobile-ui .hero__scroll {
  padding: 1rem;
}

body.is-mobile-ui .hero__scene {
  order: initial;
  min-height: 19rem;
  padding: 0.7rem;
}

body.is-mobile-ui .study-video,
body.is-android-app .study-video {
  grid-template-columns: 1fr;
}

body.is-mobile-ui .xiang-hall__body,
body.is-android-app .xiang-hall__body,
body.is-mobile-ui .daoyi-hall__body,
body.is-android-app .daoyi-hall__body,
body.is-mobile-ui .daoyi-reader-layout,
body.is-android-app .daoyi-reader-layout,
body.is-mobile-ui .daoyi-detail-layout,
body.is-android-app .daoyi-detail-layout,
body.is-mobile-ui .heluo-atlas__body,
body.is-android-app .heluo-atlas__body,
body.is-mobile-ui .culture-hall__body,
body.is-android-app .culture-hall__body,
body.is-mobile-ui .qi-scroll__body,
body.is-android-app .qi-scroll__body,
body.is-mobile-ui .xiang-panel__hero,
body.is-android-app .xiang-panel__hero,
body.is-mobile-ui .xiang-panel__blocks,
body.is-android-app .xiang-panel__blocks {
  grid-template-columns: 1fr;
}

body.is-mobile-ui .qi-scroll__detail-wings,
body.is-mobile-ui .qi-scroll__blocks,
body.is-mobile-ui .qi-scroll__metrics,
body.is-mobile-ui .daoyi-detail__chapters,
body.is-mobile-ui .culture-panel__metrics,
body.is-mobile-ui .culture-panel__cards,
body.is-mobile-ui .culture-panel__shelf-grid,
body.is-android-app .qi-scroll__detail-wings,
body.is-android-app .qi-scroll__blocks,
body.is-android-app .qi-scroll__metrics,
body.is-android-app .daoyi-detail__chapters,
body.is-android-app .culture-panel__metrics,
body.is-android-app .culture-panel__cards,
body.is-android-app .culture-panel__shelf-grid,
body.is-mobile-ui .qi-scroll__ribbon,
body.is-android-app .qi-scroll__ribbon,
body.is-mobile-ui .qi-scroll__message-grid,
body.is-android-app .qi-scroll__message-grid {
  grid-template-columns: 1fr;
}

body.is-mobile-ui .culture-panel__shelf-grid,
body.is-android-app .culture-panel__shelf-grid {
  max-height: none;
  overflow: visible;
  padding-right: 0;
}

body.is-mobile-ui .qi-scroll__track,
body.is-android-app .qi-scroll__track {
  grid-auto-columns: minmax(12.2rem, 12.2rem);
}

body.is-mobile-ui .xiang-items,
body.is-mobile-ui .xiang-panel__metrics,
body.is-mobile-ui .daoyi-chapter-grid,
body.is-android-app .xiang-items,
body.is-android-app .xiang-panel__metrics,
body.is-android-app .daoyi-chapter-grid {
  grid-template-columns: 1fr;
}

body.is-mobile-ui .daoyi-rail,
body.is-android-app .daoyi-rail {
  position: static;
  padding: 0.9rem;
}

body.is-mobile-ui .daoyi-overview,
body.is-mobile-ui .daoyi-reader,
body.is-mobile-ui .daoyi-detail,
body.is-android-app .daoyi-overview,
body.is-android-app .daoyi-reader,
body.is-android-app .daoyi-detail {
  padding: 0.92rem;
}

body.is-mobile-ui .study-video__chapters,
body.is-mobile-ui .study-video-shelf,
body.is-android-app .study-video__chapters,
body.is-android-app .study-video-shelf {
  grid-template-columns: 1fr;
}

body.is-mobile-ui .hero__painting {
  inset: 0.7rem 0.7rem 5.3rem;
}

body.is-mobile-ui .hero__legend {
  left: 0.7rem;
  right: 0.7rem;
  bottom: 0.7rem;
  padding: 0.75rem 0.9rem;
}

body.is-mobile-ui .hero__link {
  min-width: 0;
  width: 100%;
  justify-content: center;
  text-align: center;
}

body.is-android-app .hero__menu {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.75rem;
}

body.is-android-app .hero__link {
  min-width: 0;
  width: 100%;
  min-height: 4rem;
  display: grid;
  place-items: center;
  border-radius: 1.1rem;
  background: linear-gradient(180deg, rgba(255, 251, 243, 0.96), rgba(248, 236, 206, 0.9));
  border: 1px solid rgba(126, 90, 55, 0.12);
  box-shadow: 0 10px 22px rgba(53, 34, 16, 0.06);
}

body.is-android-app .game-lab__body {
  grid-template-columns: 1fr;
  gap: 0.9rem;
}

body.is-android-app .game-lab__sidebar {
  gap: 0.8rem;
}

body.is-android-app .game-scroll,
body.is-android-app .game-board {
  border-radius: 1.25rem;
}

body.is-android-app .game-scroll {
  padding: 0.95rem 1rem 1rem;
}

body.is-android-app .game-scroll__actions {
  display: none;
}

body.is-android-app .game-scroll__prologue {
  gap: 0.45rem;
}

body.is-android-app .game-realm-switch,
body.is-android-app .game-stage-rail {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: minmax(11rem, 72vw);
  overflow-x: auto;
  gap: 0.7rem;
  padding-bottom: 0.2rem;
  scrollbar-width: none;
}

body.is-android-app .game-realm-switch::-webkit-scrollbar,
body.is-android-app .game-stage-rail::-webkit-scrollbar {
  display: none;
}

body.is-android-app .game-board {
  padding: 1rem;
}

body.is-android-app .game-lab[data-focus="question"] .game-lab__body {
  gap: 0.65rem;
}

body.is-android-app .game-lab[data-focus="question"] .game-lab__sidebar {
  gap: 0.55rem;
}

body.is-android-app .game-lab[data-focus="question"] .game-scroll,
body.is-android-app .game-lab[data-focus="question"] .game-stage-rail {
  display: none;
}

body.is-android-app .game-lab[data-focus="question"] .game-realm-switch {
  grid-auto-columns: minmax(7rem, 34vw);
  gap: 0.5rem;
}

body.is-android-app .game-lab[data-focus="question"] .game-realm-button {
  gap: 0.55rem;
  padding: 0.62rem 0.72rem;
  border-radius: 1rem;
}

body.is-android-app .game-lab[data-focus="question"] .game-realm-button__seal {
  width: 2.35rem;
  font-size: 1.05rem;
  border-radius: 0.8rem;
}

body.is-android-app .game-lab[data-focus="question"] .game-realm-button__label {
  font-size: 0.7rem;
  letter-spacing: 0.08rem;
}

body.is-android-app .game-lab[data-focus="question"] .game-realm-button__title {
  font-size: 1rem;
}

body.is-android-app .game-board[data-focus="question"] {
  padding: 0.9rem 0.9rem 1rem;
}

body.is-android-app .game-board[data-focus="question"] .game-board__head {
  gap: 0.65rem;
}

body.is-android-app .game-board[data-focus="question"] .game-board__title {
  font-size: clamp(1.35rem, 6vw, 1.75rem);
}

body.is-android-app .game-board[data-focus="question"] .game-board__subtitle {
  margin-top: 0.2rem;
  font-size: 0.9rem;
  line-height: 1.45;
}

body.is-android-app .game-board[data-focus="question"] .game-board__progress {
  width: 100%;
  min-width: 0;
  gap: 0.45rem;
}

body.is-android-app .game-board[data-focus="question"] .game-board__progress-track {
  height: 0.5rem;
}

body.is-android-app .game-board[data-focus="question"] .game-board__stats {
  gap: 0.45rem;
}

body.is-android-app .game-board[data-focus="question"] .game-board__stat {
  padding: 0.5rem 0.55rem;
  border-radius: 0.85rem;
}

body.is-android-app .game-board[data-focus="question"] .game-board__stat strong {
  font-size: 1rem;
}

body.is-android-app .game-board[data-focus="question"] .game-board__stat em {
  font-size: 0.72rem;
  letter-spacing: 0.08rem;
}

body.is-android-app .game-board[data-focus="question"] .game-board__invocation {
  display: none;
}

body.is-android-app .game-board__arena {
  margin-top: 0.85rem;
}

body.is-android-app .game-questionlab {
  gap: 0.8rem;
  padding: 0;
}

body.is-android-app .game-questionlab__head,
body.is-android-app .game-questionlab__panel,
body.is-android-app .game-questionlab__poster-card,
body.is-android-app .game-cast__poster,
body.is-android-app .game-cast__formula {
  padding: 0.88rem 0.92rem;
  border-radius: 1.15rem;
  box-shadow: 0 10px 24px rgba(143, 103, 58, 0.08);
}

body.is-android-app .game-questionlab__layout--split,
body.is-android-app .game-questionlab__layout--time,
body.is-android-app .game-questionlab__layout--poster,
body.is-android-app .game-questionlab--cast .game-questionlab__layout--poster {
  grid-template-columns: 1fr;
}

body.is-android-app .game-questionlab__stack {
  gap: 0.8rem;
}

body.is-android-app .game-questionlab__segments,
body.is-android-app .game-mingji__ticket-grid,
body.is-android-app .game-duanji__hexagram-grid {
  grid-template-columns: 1fr;
}

body.is-android-app .game-questionlab__bins,
body.is-android-app .game-questionlab__gates,
body.is-android-app .game-questionlab__times,
body.is-android-app .game-mingji__slot-grid,
body.is-android-app .game-mingji__state-grid,
body.is-android-app .game-mingji__verdict-grid,
body.is-android-app .game-duanji__marker-grid,
body.is-android-app .game-duanji__poster-figures {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

body.is-android-app .game-questionlab__cards,
body.is-android-app .game-questionlab__segments,
body.is-android-app .game-cast__poster-figures {
  grid-template-columns: 1fr;
}

body.is-android-app .game-cast__shichen-grid,
body.is-android-app .game-cast__chip-grid,
body.is-android-app .game-cast__token-grid,
body.is-android-app .game-cast__line-grid,
body.is-android-app .game-cast__poster-figures {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

body.is-android-app .game-questionlab__preview-title {
  font-size: clamp(1.2rem, 5.5vw, 1.55rem);
}

body.is-android-app .game-questionlab__panel-label,
body.is-android-app .game-questionlab__label,
body.is-android-app .game-questionlab__poster-title {
  font-size: 0.74rem;
  letter-spacing: 0.12rem;
}

body.is-android-app .game-questionlab__raw {
  font-size: 0.98rem;
}

body.is-android-app .game-questionlab__panel--scene,
body.is-android-app .game-questionlab__poster,
body.is-android-app .game-questionlab__poster-card {
  max-height: 14.5rem;
  overflow: auto;
}

body.is-android-app .game-questionlab__bin,
body.is-android-app .game-questionlab__gate,
body.is-android-app .game-questionlab__time,
body.is-android-app .game-mingji__slot,
body.is-android-app .game-duanji__choice {
  border-radius: 1rem;
}

body.is-android-app .game-questionlab__bin,
body.is-android-app .game-questionlab__gate,
body.is-android-app .game-questionlab__time,
body.is-android-app .game-questionlab__card-main,
body.is-android-app .game-mingji__slot,
body.is-android-app .game-duanji__choice {
  min-height: 4.4rem;
  padding: 0.72rem 0.78rem;
}

body.is-android-app .game-questionlab__card-main {
  min-height: 5rem;
}

body.is-android-app .game-questionlab__panel--preview,
body.is-android-app .game-questionlab__poster {
  order: -1;
}

body.is-android-app .game-questionlab__actions {
  position: sticky;
  bottom: calc(4.8rem + var(--safe-bottom));
  z-index: 3;
  justify-content: stretch;
  background: linear-gradient(180deg, rgba(248, 239, 220, 0), rgba(248, 239, 220, 0.96) 28%);
  padding-top: 0.5rem;
}

body.is-android-app .game-questionlab__confirm {
  width: 100%;
  min-height: 3.25rem;
  justify-self: stretch;
}

body.is-android-app .game-duanji__summary-row {
  flex-direction: column;
  align-items: flex-start;
  gap: 0.28rem;
}

body.is-android-app .game-duanji__summary-row strong {
  text-align: left;
}

body.is-android-app .screen-game-ritual,
body.is-android-app .screen-game-certificate {
  padding:
    calc(0.45rem + var(--safe-top))
    calc(0.45rem + var(--safe-right))
    calc(0.45rem + var(--safe-bottom))
    calc(0.45rem + var(--safe-left));
}

body.is-android-app .screen-game-ritual__mist,
body.is-android-app .screen-game-certificate__mist,
body.is-android-app .screen-game-certificate__veil {
  display: none;
}

body.is-android-app .screen-game-ritual__inner {
  width: 100%;
  height: calc(100dvh - var(--safe-top) - var(--safe-bottom) - 0.9rem);
  display: grid;
  grid-template-rows: auto auto minmax(0, 1fr);
  padding: 0.95rem 0.95rem 1rem;
  border-radius: 1.45rem;
}

body.is-android-app .screen-game-ritual__header {
  gap: 0.18rem;
}

body.is-android-app .screen-game-ritual__title {
  font-size: clamp(1.9rem, 8vw, 2.8rem);
}

body.is-android-app .screen-game-ritual__narrative {
  margin-top: 0.7rem;
  min-height: 0;
  max-height: 4.8rem;
  overflow: auto;
}

body.is-android-app .screen-game-ritual__stage {
  margin-top: 0.85rem;
  min-height: 0;
  grid-template-columns: 1fr;
  grid-template-rows: minmax(11.5rem, 1fr) auto auto auto;
  gap: 0.72rem;
  align-items: stretch;
}

body.is-android-app .screen-game-ritual__scene {
  position: relative;
  inset: auto;
  min-height: 12.5rem;
  border-radius: 1.2rem;
}

body.is-android-app .screen-game-ritual__wing,
body.is-android-app .screen-game-ritual__core {
  min-height: auto;
  padding: 0.82rem;
  border-radius: 1.2rem;
  backdrop-filter: none;
}

body.is-android-app .screen-game-ritual__wing--upper { grid-row: 2; }
body.is-android-app .screen-game-ritual__core { grid-row: 3; }
body.is-android-app .screen-game-ritual__wing--lower { grid-row: 4; }

body.is-android-app .screen-game-ritual__panel-figure .figure,
body.is-android-app .screen-game-ritual__figure .figure {
  min-width: 8.5rem;
}

body.is-android-app .screen-game-ritual__seal {
  width: 4.3rem;
  font-size: 1.7rem;
}

body.is-android-app .screen-game-ritual__result {
  font-size: clamp(1.35rem, 6vw, 2rem);
}

body.is-android-app .screen-game-ritual__scene-symbols {
  display: none;
}

body.is-android-app .screen-game-ritual__scene-moon {
  left: 8%;
  top: 10%;
  width: 4.8rem;
  height: 4.8rem;
}

body.is-android-app .screen-game-ritual__scene-temple {
  right: 12%;
  bottom: 3.6rem;
  width: 8rem;
  height: 5.4rem;
}

body.is-android-app .screen-game-ritual__scene-card--upper { left: 14%; }
body.is-android-app .screen-game-ritual__scene-card--lower { right: 14%; }

body.is-android-app .screen-game-certificate__inner {
  width: 100%;
  height: calc(100dvh - var(--safe-top) - var(--safe-bottom) - 0.9rem);
}

body.is-android-app .screen-game-certificate__close {
  top: 0;
  right: 0;
  min-width: auto;
  padding: 0.72rem 0.96rem;
}

body.is-android-app .screen-game-certificate__frame {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  gap: 0.7rem;
  width: 100%;
  height: 100%;
  padding-left: 0;
}

body.is-android-app .screen-game-certificate__seal {
  right: 3.55rem;
  top: 1.1rem;
  width: 4.8rem;
  font-size: 1.7rem;
}

body.is-android-app .screen-game-certificate__rail {
  position: relative;
  left: auto;
  top: auto;
  bottom: auto;
  width: auto;
  grid-auto-flow: column;
  grid-auto-columns: minmax(6.8rem, 1fr);
  overflow-x: auto;
  align-content: initial;
  justify-items: stretch;
  gap: 0.75rem;
  padding: 0 0 0.3rem;
}

body.is-android-app .screen-game-certificate__rail::before,
body.is-android-app .screen-game-certificate__rail::after {
  display: none;
}

body.is-android-app .screen-game-certificate__stage {
  min-height: 7rem;
  padding: 0.9rem 0.68rem 0.8rem;
  gap: 0.35rem;
}

body.is-android-app .screen-game-certificate__stage-chapter,
body.is-android-app .screen-game-certificate__stage-title {
  writing-mode: horizontal-tb;
}

body.is-android-app .screen-game-certificate__scroll {
  height: auto;
  min-height: 0;
  padding: 1.8rem 0.8rem 1rem;
  border-radius: 1.65rem;
}

body.is-android-app .screen-game-certificate__scroll-edge {
  left: 0.85rem;
  right: 0.85rem;
  height: 0.95rem;
}

body.is-android-app .screen-game-certificate__paper {
  height: 100%;
  min-height: 0;
  padding: 1rem 0.85rem;
  overflow: auto;
}

body.is-android-app .screen-game-certificate__columns {
  height: auto;
  min-height: 100%;
  grid-template-columns: 1fr;
  gap: 0.65rem;
}

body.is-android-app .screen-game-certificate__column {
  justify-items: start;
  align-content: start;
  min-height: auto;
  gap: 0.55rem;
  padding: 0.72rem 0 0.8rem;
  border-right: none;
  border-bottom: 1px dashed rgba(171, 120, 47, 0.14);
  opacity: 1;
  transform: none;
  animation: none;
}

body.is-android-app .screen-game-certificate__column:first-child,
body.is-android-app .screen-game-certificate__column:last-child {
  padding-left: 0;
  padding-right: 0;
}

body.is-android-app .screen-game-certificate__column:last-child {
  border-bottom: none;
}

body.is-android-app .screen-game-certificate__column-label {
  font-size: 0.74rem;
  letter-spacing: 0.1rem;
}

body.is-android-app .screen-game-certificate__column-text {
  writing-mode: horizontal-tb;
  text-orientation: mixed;
  white-space: normal;
  line-height: 1.72;
  font-size: 1rem;
}

body.is-android-app .screen-game-certificate__column--title .screen-game-certificate__column-text {
  font-size: 1.7rem;
  letter-spacing: 0.08rem;
}

body.is-android-app .screen-game-certificate__column--heading .screen-game-certificate__column-text {
  font-size: 1.2rem;
}

.app-home,
.app-only-screen {
  display: none;
}

body:not(.is-android-app) .app-only-screen {
  display: none !important;
}

body.is-android-app .app-tabbar {
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 0.25rem;
  backdrop-filter: blur(18px);
}

body.is-android-app .app-topbar {
  gap: 0.72rem;
  padding:
    calc(0.62rem + var(--safe-top))
    calc(0.9rem + var(--safe-right))
    0.62rem
    calc(0.9rem + var(--safe-left));
  backdrop-filter: blur(18px);
}

body.is-android-app .app-topbar__title {
  font-size: 1.4rem;
  letter-spacing: 0.04rem;
}

body.is-android-app .shell {
  width: 100%;
  padding:
    0.72rem
    calc(0.42rem + var(--safe-right))
    calc(5.9rem + var(--safe-bottom))
    calc(0.42rem + var(--safe-left));
}

body.is-android-app [data-app-screen] {
  min-height: calc(100dvh - 8.9rem - var(--safe-top) - var(--safe-bottom));
}

body.is-android-app .sky-effects,
body.is-android-app .screen-evolution,
body.is-android-app .hero__veil,
body.is-android-app .hero__particles,
body.is-android-app .hero__inner,
body.is-android-app .trigram-stage__halo,
body.is-android-app .heluo-atlas__mist,
body.is-android-app .daoyi-hall__mist,
body.is-android-app .qi-scroll__mist,
body.is-android-app .xiang-hall__mist,
body.is-android-app .game-lab__mist,
body.is-android-app .academy__mist,
body.is-android-app .culture-hall__mist {
  display: none !important;
}

body.is-android-app .hero,
body.is-android-app .trigram-showcase,
body.is-android-app .heluo-atlas,
body.is-android-app .daoyi-hall,
body.is-android-app .season-compass,
body.is-android-app .qi-scroll,
body.is-android-app .xiang-hall,
body.is-android-app .hexagram-flow,
body.is-android-app .panel,
body.is-android-app .oracle,
body.is-android-app .game-lab,
body.is-android-app .academy,
body.is-android-app .culture-hall,
body.is-android-app .hall,
body.is-android-app .app-library {
  margin-top: 0;
  border-radius: 1.45rem;
  box-shadow: 0 14px 28px rgba(53, 34, 16, 0.08);
  background: linear-gradient(180deg, rgba(252, 247, 238, 0.97), rgba(245, 236, 214, 0.94));
}

body.is-android-app .hero::before,
body.is-android-app .hero::after,
body.is-android-app .trigram-showcase::before,
body.is-android-app .heluo-atlas::before,
body.is-android-app .daoyi-hall::before,
body.is-android-app .season-compass::before,
body.is-android-app .qi-scroll::before,
body.is-android-app .xiang-hall::before,
body.is-android-app .hexagram-flow::before,
body.is-android-app .panel::before,
body.is-android-app .game-lab::before,
body.is-android-app .academy::before,
body.is-android-app .culture-hall::before,
body.is-android-app .hall::before,
body.is-android-app .app-library::before {
  display: none;
}

body.is-android-app .hero {
  min-height: auto;
}

body.is-android-app .app-home {
  display: grid;
  gap: 0.92rem;
  padding: 1rem;
  position: relative;
  z-index: 1;
}

body.is-android-app .app-home__hero-card,
body.is-android-app .app-home__section,
body.is-android-app .app-library__group {
  border-radius: 1.2rem;
  border: 1px solid rgba(126, 90, 55, 0.12);
  background: linear-gradient(180deg, rgba(255, 252, 245, 0.98), rgba(246, 235, 210, 0.92));
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.35);
}

body.is-android-app .app-home__hero-card {
  display: grid;
  gap: 1rem;
  padding: 1rem;
  background:
    radial-gradient(circle at top right, rgba(205, 162, 82, 0.18), transparent 32%),
    linear-gradient(180deg, rgba(255, 252, 245, 0.99), rgba(246, 235, 210, 0.93));
}

body.is-android-app .app-home__eyebrow,
body.is-android-app .app-home__section-label,
body.is-android-app .app-library__label,
body.is-android-app .app-library__group-label {
  margin: 0;
  font-size: 0.74rem;
  letter-spacing: 0.14rem;
  color: var(--ink-soft);
}

body.is-android-app .app-home__hero-head {
  display: flex;
  align-items: center;
  gap: 0.9rem;
}

body.is-android-app .app-home__seal,
body.is-android-app .app-library__seal {
  width: 3.5rem;
  height: 3.5rem;
  flex: none;
  display: grid;
  place-items: center;
  border-radius: 1rem;
  border: 1px solid rgba(157, 47, 32, 0.24);
  background: radial-gradient(circle at 32% 28%, rgba(255, 255, 255, 0.44), transparent 34%), rgba(250, 245, 235, 0.96);
  color: var(--vermillion);
  font-family: var(--font-display);
  font-size: 1.6rem;
  box-shadow: inset 0 0 0 0.28rem rgba(157, 47, 32, 0.05);
}

body.is-android-app .app-home__hero-titles,
body.is-android-app .app-library__titles,
body.is-android-app .app-library__group-head {
  display: grid;
  gap: 0.18rem;
}

body.is-android-app .app-home__title,
body.is-android-app .app-library__title,
body.is-android-app .app-home__section-title,
body.is-android-app .app-library__group-title {
  margin: 0;
  font-family: var(--font-display);
  letter-spacing: 0.06rem;
  color: var(--ink-strong);
}

body.is-android-app .app-home__title {
  font-size: clamp(2rem, 8vw, 2.7rem);
}

body.is-android-app .app-home__subtitle,
body.is-android-app .app-library__note,
body.is-android-app .app-home__summary {
  margin: 0;
  color: var(--ink-soft);
  line-height: 1.65;
}

body.is-android-app .app-home__verses {
  display: grid;
  gap: 0.32rem;
}

body.is-android-app .app-home__verse {
  margin: 0;
  font-size: 0.96rem;
  color: var(--ink-strong);
  line-height: 1.6;
}

body.is-android-app .app-home__terms,
body.is-android-app .app-home__chip-list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

body.is-android-app .app-home__term,
body.is-android-app .app-home__chip {
  padding: 0.46rem 0.82rem;
  border-radius: 999px;
  border: 1px solid rgba(126, 90, 55, 0.12);
  background: rgba(255, 250, 242, 0.94);
  color: var(--ink-soft);
  font-size: 0.82rem;
  text-decoration: none;
}

body.is-android-app .app-home__hero-actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.72rem;
}

body.is-android-app .app-home__hero-button,
body.is-android-app .app-library__card,
body.is-android-app .app-home__quick-card,
body.is-android-app .app-home__feature-card {
  text-decoration: none;
  color: inherit;
}

body.is-android-app .app-home__hero-button {
  display: grid;
  place-items: center;
  min-height: 3.3rem;
  padding: 0.78rem 0.9rem;
  border-radius: 1rem;
  border: 1px solid rgba(126, 90, 55, 0.12);
  background: rgba(255, 251, 244, 0.95);
  color: var(--ink-strong);
  font-weight: 600;
}

body.is-android-app .app-home__hero-button--primary {
  background: linear-gradient(135deg, rgba(164, 51, 33, 0.96), rgba(125, 32, 20, 0.96));
  color: rgba(255, 247, 237, 0.98);
  border-color: rgba(125, 32, 20, 0.28);
}

body.is-android-app .app-home__section {
  display: grid;
  gap: 0.8rem;
  padding: 1rem;
}

body.is-android-app .app-home__section-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.8rem;
}

body.is-android-app .app-home__quick-grid,
body.is-android-app .app-home__feature-list,
body.is-android-app .app-library__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.72rem;
}

body.is-android-app .app-home__quick-card,
body.is-android-app .app-home__feature-card,
body.is-android-app .app-library__card {
  display: grid;
  align-content: start;
  gap: 0.34rem;
  min-height: 7.3rem;
  padding: 0.88rem 0.9rem;
  border-radius: 1.05rem;
  border: 1px solid rgba(126, 90, 55, 0.12);
  background: linear-gradient(180deg, rgba(255, 251, 243, 0.96), rgba(248, 236, 206, 0.92));
}

body.is-android-app .app-home__feature-card--wide {
  grid-column: 1 / -1;
  min-height: 6.2rem;
}

body.is-android-app .app-home__quick-seal,
body.is-android-app .app-home__feature-seal,
body.is-android-app .app-library__card-seal {
  width: 2.2rem;
  height: 2.2rem;
  display: grid;
  place-items: center;
  border-radius: 999px;
  background: rgba(157, 47, 32, 0.1);
  color: var(--vermillion);
  font-family: var(--font-display);
  font-size: 1rem;
}

body.is-android-app .app-home__quick-title,
body.is-android-app .app-library__card-title,
body.is-android-app .app-home__feature-copy strong {
  font-size: 1rem;
  color: var(--ink-strong);
}

body.is-android-app .app-home__quick-note,
body.is-android-app .app-library__card-note,
body.is-android-app .app-home__feature-copy span {
  color: var(--ink-soft);
  font-size: 0.86rem;
  line-height: 1.55;
}

body.is-android-app .app-home__feature-copy,
body.is-android-app .app-library__card {
  display: grid;
  gap: 0.26rem;
}

body.is-android-app .app-only-screen.is-app-active {
  display: block;
}

body.is-android-app .app-library {
  padding: 1rem;
}

body.is-android-app .app-library__head {
  padding: 0.08rem 0 0.9rem;
}

body.is-android-app .app-library__heading {
  display: flex;
  align-items: flex-start;
  gap: 0.9rem;
}

body.is-android-app .app-library__body {
  display: grid;
  gap: 0.85rem;
}

body.is-android-app .app-library__group {
  padding: 0.95rem;
}

body.is-android-app .trigram-showcase__heading,
body.is-android-app .heluo-atlas__heading,
body.is-android-app .daoyi-hall__heading,
body.is-android-app .season-compass__heading,
body.is-android-app .qi-scroll__heading,
body.is-android-app .xiang-hall__heading,
body.is-android-app .hexagram-flow__heading,
body.is-android-app .academy__heading,
body.is-android-app .culture-hall__heading,
body.is-android-app .oracle__heading,
body.is-android-app .game-lab__heading {
  gap: 0.72rem;
}

body.is-android-app .trigram-showcase__head,
body.is-android-app .heluo-atlas__head,
body.is-android-app .daoyi-hall__head,
body.is-android-app .season-compass__head,
body.is-android-app .qi-scroll__head,
body.is-android-app .xiang-hall__head,
body.is-android-app .hexagram-flow__head,
body.is-android-app .academy__head,
body.is-android-app .culture-hall__head,
body.is-android-app .panel__head,
body.is-android-app .oracle__head,
body.is-android-app .hall__head,
body.is-android-app .game-lab__head {
  padding: 1rem 1rem 0.25rem;
}

body.is-android-app .trigram-showcase__title,
body.is-android-app .heluo-atlas__title,
body.is-android-app .daoyi-hall__title,
body.is-android-app .season-compass__title,
body.is-android-app .qi-scroll__title,
body.is-android-app .xiang-hall__title,
body.is-android-app .hexagram-flow__title,
body.is-android-app .academy__title,
body.is-android-app .culture-hall__title,
body.is-android-app .game-lab__title,
body.is-android-app .panel__title,
body.is-android-app .oracle__title,
body.is-android-app .hall__title {
  font-size: clamp(1.75rem, 7vw, 2.25rem);
  letter-spacing: 0.08rem;
}

body.is-android-app .trigram-showcase__label,
body.is-android-app .heluo-atlas__label,
body.is-android-app .daoyi-hall__label,
body.is-android-app .season-compass__label,
body.is-android-app .qi-scroll__label,
body.is-android-app .xiang-hall__label,
body.is-android-app .hexagram-flow__label,
body.is-android-app .academy__label,
body.is-android-app .culture-hall__label,
body.is-android-app .oracle__label,
body.is-android-app .game-lab__label {
  font-size: 0.72rem;
  letter-spacing: 0.14rem;
}

body.is-android-app .heluo-atlas__note,
body.is-android-app .daoyi-hall__note,
body.is-android-app .qi-scroll__note,
body.is-android-app .xiang-hall__note,
body.is-android-app .culture-hall__note {
  display: none;
}

body.is-android-app .trigram-stage,
body.is-android-app .season-compass__body,
body.is-android-app .heluo-atlas__body,
body.is-android-app .daoyi-hall__body,
body.is-android-app .qi-scroll__body,
body.is-android-app .xiang-hall__body,
body.is-android-app .culture-hall__body,
body.is-android-app .academy__body,
body.is-android-app .hexagram-flow__panel,
body.is-android-app .oracle__body,
body.is-android-app .hall__head + .gua-grid {
  padding-left: 1rem;
  padding-right: 1rem;
}

body.is-android-app .heluo-atlas__body,
body.is-android-app .daoyi-hall__body,
body.is-android-app .culture-hall__body,
body.is-android-app .qi-scroll__body,
body.is-android-app .xiang-hall__body,
body.is-android-app .academy__body {
  gap: 0.72rem;
  padding-bottom: 1rem;
}

body.is-android-app .heluo-atlas__aside-copy,
body.is-android-app .daoyi-guide {
  display: none;
}

body.is-android-app .heluo-atlas__sidebar,
body.is-android-app .daoyi-hall__sidebar,
body.is-android-app .culture-hall__sidebar,
body.is-android-app .qi-scroll__aside,
body.is-android-app .xiang-hall__sidebar {
  gap: 0.72rem;
  padding: 0.78rem;
}

body.is-android-app .heluo-nav,
body.is-android-app .daoyi-nav,
body.is-android-app .culture-nav,
body.is-android-app .study-nav,
body.is-android-app .xiang-nav,
body.is-android-app .qi-scroll__season-nav {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: minmax(10.6rem, 72vw);
  grid-template-columns: none;
  gap: 0.62rem;
  overflow-x: auto;
  padding-bottom: 0.16rem;
  scrollbar-width: none;
}

body.is-android-app .heluo-nav::-webkit-scrollbar,
body.is-android-app .daoyi-nav::-webkit-scrollbar,
body.is-android-app .culture-nav::-webkit-scrollbar,
body.is-android-app .study-nav::-webkit-scrollbar,
body.is-android-app .xiang-nav::-webkit-scrollbar,
body.is-android-app .qi-scroll__season-nav::-webkit-scrollbar {
  display: none;
}

body.is-android-app .heluo-nav__button,
body.is-android-app .daoyi-nav__button,
body.is-android-app .culture-nav__button,
body.is-android-app .study-nav__button,
body.is-android-app .xiang-nav__button,
body.is-android-app .qi-scroll__season-button {
  width: auto;
  min-height: 4.5rem;
  padding: 0.76rem 0.86rem;
  opacity: 1;
  transform: none;
  animation: none;
  box-shadow: none;
}

body.is-android-app .heluo-nav__button:hover,
body.is-android-app .daoyi-nav__button:hover,
body.is-android-app .culture-nav__button:hover,
body.is-android-app .study-nav__button:hover,
body.is-android-app .xiang-nav__button:hover,
body.is-android-app .qi-scroll__season-button:hover {
  transform: none;
  box-shadow: none;
}

body.is-android-app .heluo-nav__note,
body.is-android-app .daoyi-nav__note,
body.is-android-app .culture-nav__label,
body.is-android-app .study-nav__label,
body.is-android-app .xiang-nav__note {
  font-size: 0.76rem;
  line-height: 1.35;
}

body.is-android-app .heluo-nav__title,
body.is-android-app .daoyi-nav__title,
body.is-android-app .culture-nav__title,
body.is-android-app .study-nav__title,
body.is-android-app .xiang-nav__title {
  font-size: 1.02rem;
}

body.is-android-app .heluo-panel__hero,
body.is-android-app .daoyi-overview,
body.is-android-app .daoyi-reader,
body.is-android-app .daoyi-detail,
body.is-android-app .culture-panel__article,
body.is-android-app .study-panel__article,
body.is-android-app .qi-scroll__detail-card,
body.is-android-app .xiang-panel__article,
body.is-android-app .season-compass__detail-card,
body.is-android-app .hexagram-flow__panel,
body.is-android-app .result-summary,
body.is-android-app .oracle-catalog {
  border-radius: 1.2rem;
}

body.is-android-app .heluo-panel__hero,
body.is-android-app .qi-scroll__detail-card,
body.is-android-app .xiang-panel__article,
body.is-android-app .culture-panel__article,
body.is-android-app .study-panel__article {
  padding: 0.92rem;
}

body.is-android-app .panel__head,
body.is-android-app .hall__head {
  gap: 0.7rem;
}

body.is-android-app .method-switch {
  width: 100%;
  overflow-x: auto;
  flex-wrap: nowrap;
  padding-bottom: 0.15rem;
  scrollbar-width: none;
}

body.is-android-app .method-switch::-webkit-scrollbar {
  display: none;
}

body.is-android-app .method-switch__button {
  white-space: nowrap;
  padding: 0.6rem 0.95rem;
}

body.is-android-app .topic-field textarea,
body.is-android-app #lotQuestion {
  min-height: 4rem;
  line-height: 1.68;
}

body.is-android-app .result-summary,
body.is-android-app .result-grid,
body.is-android-app .divination-insights,
body.is-android-app .oracle-catalog,
body.is-android-app .gua-grid {
  margin-top: 0.78rem;
}

body.is-android-app .oracle-catalog__head {
  margin-bottom: 0.72rem;
}

body.is-android-app .oracle-catalog__grid,
body.is-android-app .gua-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

body.is-android-app .panel__forms {
  gap: 0.78rem;
}

body.is-android-app .topic-field {
  padding: 0.82rem 0.9rem;
  gap: 0.38rem;
  border-radius: 1rem;
}

body.is-android-app .topic-field__label,
body.is-android-app .field__label {
  font-size: 0.78rem;
  letter-spacing: 0.12rem;
}

body.is-android-app .method-panel {
  gap: 0.62rem;
}

body.is-android-app .field {
  min-height: 3rem;
  padding: 0.54rem 0.78rem;
  border-radius: 1rem;
}

body.is-android-app .panel__actions,
body.is-android-app .oracle-ritual__actions {
  display: flex;
  justify-content: stretch;
}

body.is-android-app .panel__actions .panel__button,
body.is-android-app .oracle-ritual__actions .panel__button {
  width: 100%;
}

body.is-android-app .oracle__body {
  margin-top: 0.78rem;
  gap: 0.78rem;
  padding-bottom: 1rem;
}

body.is-android-app .oracle-ritual,
body.is-android-app .oracle-result,
body.is-android-app .oracle-catalog {
  border-radius: 1.2rem;
}

body.is-android-app .oracle-ritual {
  gap: 0.72rem;
  padding: 0.9rem;
}

body.is-android-app .oracle-ritual__field {
  order: 1;
}

body.is-android-app .oracle-ritual__actions {
  order: 2;
}

body.is-android-app .oracle-stage {
  order: 3;
  min-height: 12.4rem;
  border-radius: 1.2rem;
}

body.is-android-app .oracle-stage__mist,
body.is-android-app .oracle-stage__halo {
  display: none;
}

body.is-android-app .oracle-stage__tube {
  bottom: 0.9rem;
  width: min(11.4rem, 72%);
  height: 8.9rem;
}

body.is-android-app .oracle-stage__mouth {
  top: -0.7rem;
  height: 1.8rem;
}

body.is-android-app .oracle-stage__sticks {
  bottom: 3rem;
  width: min(10.8rem, 78%);
  height: 10.2rem;
}

body.is-android-app .oracle-stage__seal-mark {
  bottom: 1.05rem;
  padding: 0.38rem 1rem;
  font-size: 0.88rem;
}

body.is-android-app .oracle-stage__slip {
  bottom: 3.2rem;
  width: min(7.6rem, 34vw);
  min-height: 8.6rem;
  padding: 0.72rem 0.62rem 0.82rem;
  gap: 0.3rem;
}

body.is-android-app .oracle-stage__slip-no {
  font-size: 1.08rem;
}

body.is-android-app .oracle-stage__slip-mark,
body.is-android-app .oracle-stage__slip-meta {
  font-size: 0.76rem;
}

body.is-android-app .oracle-stage[data-mode="idle"] .oracle-stage__slip {
  transform: translate(-50%, 1rem) rotate(-1deg) scale(0.92);
}

body.is-android-app .oracle-stage[data-mode="reveal"] .oracle-stage__slip {
  transform: translate(-50%, -6.8rem) rotate(-8deg) scale(1.02);
}

body.is-android-app .oracle-result__head,
body.is-android-app .oracle-catalog__head {
  gap: 0.45rem;
}

body.is-android-app .oracle-result__title,
body.is-android-app .oracle-catalog__title {
  font-size: clamp(1.55rem, 6vw, 2rem);
}

body.is-android-app .game-lab,
body.is-android-app [data-app-screen="game"] {
  display: none !important;
}

@media (max-width: 420px) {
  body.is-android-app .app-home__hero-actions,
  body.is-android-app .app-home__quick-grid,
  body.is-android-app .app-home__feature-list,
  body.is-android-app .app-library__grid {
    grid-template-columns: 1fr;
  }

  body.is-android-app .app-home__feature-card--wide {
    grid-column: auto;
  }

  body.is-android-app .app-tabbar__label {
    font-size: 0.62rem;
  }
}

body.is-mobile-ui .game-realm-switch,
body.is-mobile-ui .game-stage-rail {
  grid-auto-flow: column;
  grid-auto-columns: minmax(15rem, 82vw);
  overflow-x: auto;
  padding-bottom: 0.15rem;
  scrollbar-width: none;
}

body.is-mobile-ui .game-realm-switch::-webkit-scrollbar,
body.is-mobile-ui .game-stage-rail::-webkit-scrollbar {
  display: none;
}

body.is-mobile-ui .game-board__head,
body.is-mobile-ui .game-board__footer {
  flex-direction: column;
}

body.is-mobile-ui .game-board__progress,
body.is-mobile-ui .game-reward {
  width: 100%;
  min-width: 0;
}

body.is-mobile-ui .game-board__stats {
  grid-template-columns: 1fr;
}

body.is-mobile-ui .game-questionlab__layout--split,
body.is-mobile-ui .game-questionlab__layout--time,
body.is-mobile-ui .game-questionlab__layout--poster,
body.is-mobile-ui .game-questionlab--cast .game-questionlab__layout--poster {
  grid-template-columns: 1fr;
}

body.is-mobile-ui .game-questionlab__bins,
body.is-mobile-ui .game-questionlab__gates,
body.is-mobile-ui .game-questionlab__times,
body.is-mobile-ui .game-questionlab__segments,
body.is-mobile-ui .game-questionlab__cards,
body.is-mobile-ui .game-cast__shichen-grid,
body.is-mobile-ui .game-cast__chip-grid,
body.is-mobile-ui .game-cast__token-grid,
body.is-mobile-ui .game-cast__line-grid,
body.is-mobile-ui .game-cast__poster-figures,
body.is-mobile-ui .game-mingji__intro,
body.is-mobile-ui .game-mingji__ticket-grid,
body.is-mobile-ui .game-mingji__slot-grid,
body.is-mobile-ui .game-mingji__poster-figures,
body.is-mobile-ui .game-mingji__verdict-grid,
body.is-mobile-ui .game-mingji__state-grid,
body.is-mobile-ui .game-duanji__intro,
body.is-mobile-ui .game-duanji__hexagram-grid,
body.is-mobile-ui .game-duanji__poster-figures,
body.is-mobile-ui .game-duanji__marker-grid {
  grid-template-columns: 1fr;
}

body.is-mobile-ui .game-questionlab__actions {
  justify-content: stretch;
}

body.is-mobile-ui .game-questionlab__confirm,
body.is-mobile-ui .game-board__actions .panel__button,
body.is-mobile-ui .game-yinyang__action {
  width: 100%;
}

body.is-mobile-ui .game-questionlab__gate,
body.is-mobile-ui .game-mingji__slot-top,
body.is-mobile-ui .game-mingji__state-top,
body.is-mobile-ui .game-duanji__choice-top {
  flex-wrap: wrap;
  align-items: flex-start;
}

body.is-mobile-ui .game-duanji__summary-row {
  flex-direction: column;
  align-items: flex-start;
  gap: 0.35rem;
}

body.is-mobile-ui .game-duanji__summary-row strong {
  text-align: left;
}

body.is-mobile-ui .screen-castflow__inner {
  width: min(100vw - 0.5rem, 1280px);
  height: min(100vh - 0.5rem, 860px);
}

body.is-mobile-ui .screen-castflow__rail {
  grid-template-columns: 1fr;
}

body.is-low-motion::before,
body.is-low-motion::after,
body.is-low-motion .intro__mist,
body.is-low-motion .screen-ritual__mist,
body.is-low-motion .screen-castflow__mist,
body.is-low-motion .screen-evolution__mist,
body.is-low-motion .screen-game-ritual__mist,
body.is-low-motion .screen-game-certificate__mist,
body.is-low-motion .screen-game-certificate__veil,
body.is-low-motion .hero__mist,
body.is-low-motion .hero__particles,
body.is-low-motion .game-lab__mist,
body.is-low-motion .academy__mist,
body.is-low-motion .daoyi-hall__mist,
body.is-low-motion .heluo-atlas__mist,
body.is-low-motion .culture-hall__mist,
body.is-low-motion .oracle-stage__mist,
body.is-low-motion .sky-effects,
body.is-low-motion .screen-game-ritual__scene-mist {
  display: none !important;
}

body.is-low-motion .topbar,
body.is-low-motion .hero__legend,
body.is-low-motion .game-scroll,
body.is-low-motion .game-board,
body.is-low-motion .oracle-result__card {
  backdrop-filter: none !important;
}

body.is-low-motion *,
body.is-low-motion *::before,
body.is-low-motion *::after {
  animation-duration: 0.01ms !important;
  animation-iteration-count: 1 !important;
  transition-duration: 0.12s !important;
  scroll-behavior: auto !important;
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}
