:root {
  color-scheme: dark;
  /* 墨色绢底：略暖的深底，克制、偏传统审美 */
  --bg-deep: #080706;
  --bg: #12100e;
  --bg-elevated: #1a1815;
  --fg: #f2ebe4;
  --fg-soft: #cfc6b8;
  --muted: #958c80;
  --muted2: #6a645c;
  --card: rgba(255, 248, 235, 0.045);
  --card-hover: rgba(255, 248, 235, 0.075);
  /* 主强调：仿古金 / 浅赭，避免高饱和「网页蓝」 */
  --accent: #c4a574;
  --accent-strong: #e0d0a8;
  --accent-dim: rgba(196, 165, 116, 0.22);
  --gold: #d4bc82;
  --gold-dim: rgba(212, 188, 130, 0.14);
  --border: rgba(220, 200, 170, 0.11);
  --border-strong: rgba(230, 210, 180, 0.16);
  --shadow-sm: 0 2px 8px rgba(0, 0, 0, 0.38);
  --shadow-md: 0 12px 40px rgba(0, 0, 0, 0.48);
  --radius: 12px;
  --radius-sm: 8px;
  --wrap-max: 1180px;
  /* 子页表单、结果报告等主阅读列宽（上下区块对齐用） */
  --content-column: 40rem;
  --font: "Source Han Sans SC", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", system-ui,
    -apple-system, "Segoe UI", sans-serif;
  /* 标题略偏刻本/榜书气质，无额外网络字体依赖 */
  --font-serif: "Source Han Serif SC", "Noto Serif SC", "Songti SC", "STSong", "SimSun", serif;
  /* 模块：木青（八字）、土金（取名）、火土（择日）、天色墨（星座） */
  --mod-bazhi: #8eb0a4;
  --mod-bazhi-mid: #6a8f82;
  --mod-bazhi-deep: #3d5248;
  --mod-naming: #d8c896;
  --mod-naming-mid: #b89a58;
  --mod-naming-deep: #7a6630;
  --mod-zeliang: #cfa882;
  --mod-zeliang-mid: #a67d52;
  --mod-zeliang-deep: #6e4a30;
  --mod-xingzuo: #9aa6b8;
  --mod-xingzuo-mid: #6f7a8e;
  --mod-xingzuo-deep: #454c5a;
  --mod-mingzi: #b8a0d4;
  --mod-mingzi-mid: #8f78b0;
  --mod-mingzi-deep: #4f3f68;
  --mod-dream: #9cb8d8;
  --mod-dream-mid: #6e8eb8;
  --mod-dream-deep: #3f5568;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  min-height: 100vh;
  font-family: var(--font);
  font-size: 1.02rem;
  color: var(--fg);
  line-height: 1.65;
  background-color: var(--bg-deep);
  background-image:
    radial-gradient(ellipse 82% 48% at 50% -14%, rgba(120, 96, 64, 0.07), transparent 48%),
    radial-gradient(ellipse 42% 32% at 92% 8%, rgba(55, 70, 78, 0.06), transparent 44%),
    linear-gradient(180deg, #151210 0%, var(--bg-deep) 46%, #030302 100%);
  background-attachment: fixed;
}

body.page-shell {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

body.page-shell:not(.page-with-ads) main.wrap {
  flex: 1;
}

::selection {
  background: rgba(196, 165, 116, 0.32);
  color: var(--fg);
}

a {
  color: var(--accent);
  text-decoration: none;
  transition: color 0.15s ease, opacity 0.15s ease;
}

a:hover {
  color: var(--accent-strong);
}

a:focus-visible,
button:focus-visible,
.btn:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

/* 内联 SVG 图标 sprite：不占布局，供 <use href="#…"> 引用 */
.svg-sprite {
  position: absolute;
  width: 0;
  height: 0;
  overflow: hidden;
}

.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  border-bottom: 1px solid var(--border);
  backdrop-filter: blur(12px) saturate(1.12);
  background: linear-gradient(180deg, rgba(22, 19, 16, 0.97) 0%, rgba(10, 9, 8, 0.95) 100%);
  box-shadow: 0 1px 0 rgba(220, 200, 170, 0.05), 0 8px 24px rgba(0, 0, 0, 0.32);
  overflow: hidden;
  isolation: isolate;
}

.site-header::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 2px;
  z-index: 2;
  background: linear-gradient(
    90deg,
    rgba(140, 72, 58, 0.22),
    rgba(180, 150, 100, 0.2),
    rgba(70, 82, 76, 0.18)
  );
  opacity: 0.5;
  pointer-events: none;
}

/* 页头背景：五行光晕、太极、云气、经卷字句、回纹角花 */
.site-header__art {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
}

.site-header__mist {
  position: absolute;
  inset: -20% -10%;
  background:
    radial-gradient(ellipse 42% 38% at 12% 45%, rgba(61, 143, 106, 0.09), transparent 55%),
    radial-gradient(ellipse 38% 36% at 88% 40%, rgba(42, 90, 138, 0.08), transparent 52%),
    radial-gradient(ellipse 35% 40% at 50% 110%, rgba(196, 92, 62, 0.06), transparent 50%),
    radial-gradient(ellipse 30% 45% at 72% 8%, rgba(168, 138, 72, 0.07), transparent 48%),
    radial-gradient(ellipse 28% 38% at 28% 0%, rgba(122, 130, 148, 0.06), transparent 45%);
  opacity: 0.85;
}

.site-header__wx-orbit {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -52%);
  display: flex;
  align-items: center;
  gap: clamp(0.85rem, 2.5vw, 1.75rem);
  opacity: 0.11;
  font-family: var(--font-serif);
  font-weight: 800;
  font-size: clamp(1.35rem, 3.2vw, 2.1rem);
  letter-spacing: 0.12em;
  white-space: nowrap;
  filter: blur(0.3px);
}

.site-header__wx--mu {
  color: #7eb89a;
  text-shadow: 0 0 24px rgba(100, 160, 130, 0.35);
}
.site-header__wx--huo {
  color: #d08068;
  text-shadow: 0 0 22px rgba(200, 100, 80, 0.3);
}
.site-header__wx--tu {
  color: #c4a86e;
  text-shadow: 0 0 20px rgba(180, 150, 90, 0.28);
}
.site-header__wx--jin {
  color: #a8b0c4;
  text-shadow: 0 0 20px rgba(140, 150, 180, 0.28);
}
.site-header__wx--shui {
  color: #6a9ec8;
  text-shadow: 0 0 22px rgba(80, 130, 190, 0.32);
}

.site-header__taiji {
  position: absolute;
  right: clamp(0.5rem, 4vw, 3.5rem);
  top: 50%;
  width: clamp(3.2rem, 8vw, 4.6rem);
  height: clamp(3.2rem, 8vw, 4.6rem);
  transform: translateY(-50%) rotate(-8deg);
  border-radius: 50%;
  opacity: 0.1;
  box-shadow: 0 0 0 1px rgba(255, 248, 235, 0.08), inset 0 0 12px rgba(0, 0, 0, 0.25);
  background: conic-gradient(from 45deg, #12100e 0deg 180deg, #e4dccf 180deg 360deg);
}

.site-header__dao-cloud {
  position: absolute;
  border-radius: 50%;
  background: radial-gradient(
    ellipse 80% 55% at 50% 50%,
    rgba(255, 248, 235, 0.07) 0%,
    rgba(255, 248, 235, 0.02) 45%,
    transparent 70%
  );
  opacity: 0.45;
}
.site-header__dao-cloud--1 {
  width: min(55vw, 28rem);
  height: 3.5rem;
  left: -8%;
  top: -0.5rem;
  transform: rotate(-3deg);
}
.site-header__dao-cloud--2 {
  width: min(45vw, 22rem);
  height: 2.8rem;
  right: -5%;
  bottom: -0.35rem;
  transform: rotate(5deg);
}

.site-header__scroll {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0.15rem;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.15rem 0.45rem;
  font-family: var(--font-serif);
  font-size: clamp(0.58rem, 1.1vw, 0.72rem);
  letter-spacing: 0.42em;
  color: rgba(232, 210, 180, 0.14);
  text-shadow: 0 0 12px rgba(196, 165, 116, 0.12);
  white-space: nowrap;
  overflow: hidden;
  mask-image: linear-gradient(90deg, transparent 0%, #000 8%, #000 92%, transparent 100%);
}
.site-header__scroll span {
  flex-shrink: 0;
}
.site-header__dot {
  letter-spacing: 0;
  opacity: 0.5;
}

.site-header__corner {
  position: absolute;
  width: 10px;
  height: 10px;
  border: 1px solid rgba(196, 165, 116, 0.22);
  opacity: 0.65;
}
.site-header__corner--tl {
  left: clamp(0.5rem, 2vw, 1rem);
  top: 0.45rem;
  border-right: none;
  border-bottom: none;
}
.site-header__corner--tr {
  right: clamp(0.5rem, 2vw, 1rem);
  top: 0.45rem;
  border-left: none;
  border-bottom: none;
}

.site-header .inner,
.site-footer .inner,
.wrap {
  max-width: var(--wrap-max);
  margin: 0 auto;
  padding-left: clamp(1rem, 3vw, 1.75rem);
  padding-right: clamp(1rem, 3vw, 1.75rem);
}

.site-header .inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding-top: 0.85rem;
  padding-bottom: 0.85rem;
  position: relative;
  z-index: 1;
}

.site-footer .inner {
  padding-top: 0.9rem;
  padding-bottom: 0.9rem;
}

.wrap {
  padding-top: 0;
  padding-bottom: 0;
}

.brand {
  font-family: var(--font-serif);
  font-weight: 700;
  font-size: clamp(1.2rem, 2.2vw, 1.42rem);
  letter-spacing: 0.14em;
  color: #ebe4d6;
  text-decoration: none;
}

.brand:hover {
  color: #f5efe4;
  opacity: 1;
}

.nav {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.25rem;
  font-size: 0.9rem;
  font-weight: 500;
}

.nav .nav-item {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.45rem 0.8rem;
  border-radius: var(--radius-sm);
  color: var(--fg-soft);
  border: 1px solid transparent;
  transition: background 0.18s ease, border-color 0.18s ease, color 0.18s ease;
}

.nav .nav-item:hover {
  color: var(--fg);
  background: rgba(255, 255, 255, 0.06);
  border-color: var(--border);
  text-decoration: none;
}

.nav .nav-item:hover .icon-svg--nav {
  opacity: 1;
  color: var(--accent-strong);
}

.nav-item--bazhi:hover {
  color: var(--fg);
  background: rgba(142, 176, 164, 0.1);
  border-color: rgba(142, 176, 164, 0.22);
}
.nav-item--bazhi:hover .icon-svg--nav {
  color: var(--mod-bazhi);
}

.nav-item--naming:hover {
  color: var(--fg);
  background: rgba(216, 200, 150, 0.09);
  border-color: rgba(216, 200, 150, 0.22);
}
.nav-item--naming:hover .icon-svg--nav {
  color: var(--mod-naming);
}

.nav-item--zeliang:hover {
  color: var(--fg);
  background: rgba(207, 168, 130, 0.09);
  border-color: rgba(207, 168, 130, 0.22);
}
.nav-item--zeliang:hover .icon-svg--nav {
  color: var(--mod-zeliang);
}

.nav-item--xingzuo:hover {
  color: var(--fg);
  background: rgba(154, 166, 184, 0.1);
  border-color: rgba(154, 166, 184, 0.22);
}
.nav-item--xingzuo:hover .icon-svg--nav {
  color: var(--mod-xingzuo);
}

.nav .nav-item.nav-item--current,
.nav .nav-item.nav-item--current:hover,
.nav .nav-item[aria-current="page"],
.nav .nav-item[aria-current="page"]:hover {
  text-decoration: none;
}

.nav-item--bazhi.nav-item--current {
  color: var(--fg);
  background: rgba(142, 176, 164, 0.12);
  border-color: rgba(142, 176, 164, 0.28);
}
.nav-item--bazhi.nav-item--current .icon-svg--nav {
  color: var(--mod-bazhi);
}

.nav-item--naming.nav-item--current {
  color: var(--fg);
  background: rgba(216, 200, 150, 0.11);
  border-color: rgba(216, 200, 150, 0.26);
}
.nav-item--naming.nav-item--current .icon-svg--nav {
  color: var(--mod-naming);
}

.nav-item--zeliang.nav-item--current {
  color: var(--fg);
  background: rgba(207, 168, 130, 0.11);
  border-color: rgba(207, 168, 130, 0.26);
}
.nav-item--zeliang.nav-item--current .icon-svg--nav {
  color: var(--mod-zeliang);
}

.nav-item--xingzuo.nav-item--current {
  color: var(--fg);
  background: rgba(154, 166, 184, 0.12);
  border-color: rgba(170, 180, 198, 0.28);
}
.nav-item--xingzuo.nav-item--current .icon-svg--nav {
  color: var(--mod-xingzuo);
}

.nav-item--mingzi:hover {
  color: var(--fg);
  background: rgba(184, 160, 212, 0.1);
  border-color: rgba(184, 160, 212, 0.26);
}
.nav-item--mingzi:hover .icon-svg--nav {
  color: var(--mod-mingzi);
}

.nav-item--zhougong:hover {
  color: var(--fg);
  background: rgba(156, 184, 216, 0.1);
  border-color: rgba(156, 184, 216, 0.26);
}
.nav-item--zhougong:hover .icon-svg--nav {
  color: var(--mod-dream);
}

.nav-item--mingzi.nav-item--current {
  color: var(--fg);
  background: rgba(184, 160, 212, 0.12);
  border-color: rgba(184, 160, 212, 0.28);
}
.nav-item--mingzi.nav-item--current .icon-svg--nav {
  color: var(--mod-mingzi);
}

.nav-item--zhougong.nav-item--current {
  color: var(--fg);
  background: rgba(156, 184, 216, 0.12);
  border-color: rgba(156, 184, 216, 0.28);
}
.nav-item--zhougong.nav-item--current .icon-svg--nav {
  color: var(--mod-dream);
}

.icon-svg {
  display: block;
  flex-shrink: 0;
  color: var(--accent);
}

.icon-svg--card {
  width: 1.7rem;
  height: 1.7rem;
}

.icon-svg--nav {
  width: 1.05rem;
  height: 1.05rem;
  opacity: 0.88;
}

.icon-svg--hero {
  width: 2.45rem;
  height: 2.45rem;
}

.hero--module {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 0.2rem;
}

.hero--module h1 {
  margin-top: 0.15rem;
  font-family: var(--font-serif);
  font-weight: 700;
  letter-spacing: 0.02em;
}

.hero-module-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 4.35rem;
  height: 4.35rem;
  margin-bottom: 0.35rem;
  border-radius: var(--radius);
  background: rgba(196, 165, 116, 0.08);
  border: 1px solid rgba(200, 175, 130, 0.22);
  color: var(--accent);
}

.hero-module-icon .icon-svg {
  width: 2.45rem;
  height: 2.45rem;
}

main.wrap {
  padding-top: 1.85rem;
  padding-bottom: 3rem;
}

/* 首页大 Banner：青铜框感 + 内层装饰（八卦、太极、双山剪影） */
.hero-panel {
  position: relative;
  width: 100%;
  max-width: 100%;
  margin: 0 auto 2.25rem;
  box-sizing: border-box;
  padding: 1px;
  border-radius: var(--radius);
  background: linear-gradient(135deg, rgba(130, 108, 72, 0.28), rgba(72, 82, 76, 0.22));
  box-shadow: 0 10px 36px rgba(0, 0, 0, 0.34);
  overflow: hidden;
  isolation: isolate;
}

.hero-panel__art {
  position: absolute;
  inset: 1px;
  border-radius: calc(var(--radius) - 1px);
  pointer-events: none;
  z-index: 0;
  overflow: hidden;
}

.hero-panel__mist {
  position: absolute;
  inset: -5% -8%;
  background:
    radial-gradient(ellipse 55% 42% at 18% 72%, rgba(90, 110, 95, 0.08), transparent 50%),
    radial-gradient(ellipse 48% 38% at 88% 68%, rgba(72, 88, 118, 0.07), transparent 48%),
    radial-gradient(ellipse 70% 55% at 50% 108%, rgba(196, 165, 116, 0.06), transparent 52%);
  opacity: 0.9;
}

.hero-panel__svg {
  display: block;
  width: 100%;
  height: 100%;
}

.hero-panel__svg--mounts {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  width: 100%;
  height: clamp(108px, 38%, 200px);
  min-height: 100px;
  max-height: 220px;
  opacity: 0.38;
  filter: drop-shadow(0 -2px 18px rgba(0, 0, 0, 0.35));
}

.hero-panel__bagua-wrap {
  position: absolute;
  left: clamp(0.35rem, 1.8vw, 1.1rem);
  top: clamp(0.55rem, 2vw, 1.15rem);
  width: clamp(4.75rem, 20vw, 8.75rem);
  height: clamp(4.75rem, 20vw, 8.75rem);
  opacity: 0.26;
  filter: drop-shadow(0 0 20px rgba(196, 165, 116, 0.12));
}

.hero-panel__taiji-wrap {
  position: absolute;
  right: clamp(0.35rem, 1.8vw, 1rem);
  top: clamp(0.65rem, 2.2vw, 1.35rem);
  width: clamp(3.85rem, 16vw, 6.5rem);
  height: clamp(3.85rem, 16vw, 6.5rem);
  opacity: 0.24;
  filter: drop-shadow(0 0 14px rgba(0, 0, 0, 0.25));
}

.hero-panel::before {
  content: "";
  position: absolute;
  inset: 1px;
  border-radius: calc(var(--radius) - 1px);
  pointer-events: none;
  z-index: 0;
  /* 层叠：殿宇飞檐剪影 + 远雾 + 极淡太极水印 + 墨色底 */
  background-image:
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 320 72' preserveAspectRatio='none'%3E%3Cpath d='M0 72 L40 48 L80 58 L120 42 L160 52 L200 40 L240 50 L280 38 L320 48 L320 72 Z' fill='%230a0908' fill-opacity='0.35'/%3E%3Cpath d='M0 72 L160 28 L320 72' fill='none' stroke='%23c4a574' stroke-opacity='0.14' stroke-width='0.75'/%3E%3Cpath d='M40 72 L160 36 L280 72' fill='none' stroke='%23a89070' stroke-opacity='0.1' stroke-width='0.5'/%3E%3C/svg%3E"),
    radial-gradient(ellipse 100% 80% at 50% 100%, rgba(28, 22, 18, 0.65), transparent 58%),
    radial-gradient(ellipse 55% 40% at 20% 85%, rgba(90, 72, 52, 0.12), transparent 45%),
    radial-gradient(ellipse 50% 38% at 82% 80%, rgba(85, 70, 55, 0.1), transparent 42%),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100'%3E%3Ccircle cx='50' cy='50' r='48' fill='none' stroke='%23b9a078' stroke-opacity='0.22' stroke-width='1'/%3E%3Cpath d='M50 2 A48 48 0 1 1 50 98 A24 24 0 1 1 50 50 A24 24 0 1 0 50 2 Z' fill='%23b9a078' fill-opacity='0.07'/%3E%3C/svg%3E"),
    radial-gradient(ellipse 72% 50% at 50% 0%, rgba(200, 175, 130, 0.05), transparent 50%),
    linear-gradient(165deg, #161412 0%, #0c0b0a 100%);
  background-repeat: no-repeat, no-repeat, no-repeat, no-repeat, no-repeat, no-repeat, no-repeat;
  background-position: center bottom, center bottom, center bottom, center bottom, right -6% top 6%, center top, center;
  background-size: 100% auto, 120% 55%, 100% 100%, 100% 100%, clamp(120px, 36vw, 200px) clamp(120px, 36vw, 200px), 100% 100%, 100% 100%;
}

.hero-panel .hero {
  position: relative;
  z-index: 1;
  padding: 2.25rem clamp(1.25rem, 4vw, 2.5rem) 2.35rem;
  margin: 0;
  max-width: none;
}

.hero {
  padding: 1.75rem 0 1.25rem;
  text-align: center;
  max-width: 48rem;
  margin: 0 auto;
}

.hero--home .hero-badge {
  background: rgba(40, 36, 30, 0.45);
  border-color: rgba(200, 175, 130, 0.14);
  color: var(--muted);
  letter-spacing: 0.06em;
}

.hero--home h1 {
  font-family: var(--font-serif);
  font-size: clamp(1.75rem, 3.8vw, 2.45rem);
  font-weight: 700;
  line-height: 1.3;
  margin: 0 0 1.1rem;
  letter-spacing: 0.02em;
  color: #f5efe6;
}

.hero--home .lead {
  color: var(--muted);
  font-size: 1.05rem;
  line-height: 1.75;
  max-width: 40rem;
  margin-left: auto;
  margin-right: auto;
}

.hero-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.35rem 0.75rem;
  border-radius: var(--radius-sm);
  font-size: 0.76rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: none;
  color: var(--muted);
  background: rgba(40, 36, 30, 0.4);
  border: 1px solid rgba(200, 175, 130, 0.12);
  margin-bottom: 1rem;
}

.hero h1 {
  font-family: var(--font-serif);
  font-size: clamp(1.5rem, 4.2vw, 2.15rem);
  font-weight: 700;
  line-height: 1.28;
  margin: 0 0 0.85rem;
  letter-spacing: 0.02em;
}

.hero .lead {
  margin: 0;
  font-size: 1.03rem;
  color: var(--muted);
  max-width: 40rem;
  margin-left: auto;
  margin-right: auto;
}

/* 子页顶区：分模块色带 */
.hero-banner {
  position: relative;
  padding: 1.75rem 1.5rem 1.6rem;
  margin: 0 auto 1rem;
  width: 100%;
  max-width: min(var(--content-column), 100%);
  box-sizing: border-box;
  border-radius: var(--radius);
  border: 1px solid var(--border);
  overflow: hidden;
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.32);
}

.hero-banner::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  opacity: 0.35;
  pointer-events: none;
  background: radial-gradient(circle at 12% 18%, rgba(255, 255, 255, 0.06), transparent 42%);
}

.hero-banner--bazhi {
  border-color: rgba(142, 176, 164, 0.26);
  background: linear-gradient(145deg, rgba(61, 82, 72, 0.32) 0%, rgba(10, 9, 8, 0.94) 52%, rgba(18, 16, 14, 0.98) 100%);
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.32);
}
.hero-banner--bazhi .hero-module-icon {
  background: rgba(142, 176, 164, 0.1);
  border-color: rgba(142, 176, 164, 0.26);
  color: var(--mod-bazhi);
}
.hero-banner--bazhi h1 {
  color: #e8f0ec;
}

/* 八字顶区：四柱竖线 + 天干地支水印 + 极淡太极，不压正文 */
.hero-banner--bazhi::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  z-index: 0;
  pointer-events: none;
  background-image: url("data:image/svg+xml,%3Csvg%20xmlns%3D%27http%3A//www.w3.org/2000/svg%27%20viewBox%3D%270%200%20520%20240%27%3E%3Cg%20fill%3D%27none%27%20stroke%3D%27%238eb0a4%27%20stroke-opacity%3D%270.1%27%20stroke-width%3D%270.65%27%3E%3Cpath%20d%3D%27M108%2016v208M208%2010v214M308%2014v210M408%2020v204%27/%3E%3C/g%3E%3Cg%20fill%3D%27%239ab8aa%27%20fill-opacity%3D%270.06%27%20font-family%3D%27Source%20Han%20Serif%20SC%2CNoto%20Serif%20SC%2CSimSun%2Cserif%27%20font-size%3D%2724%27%3E%3Ctext%20x%3D%276%27%20y%3D%2742%27%3E%E7%94%B2%E4%B9%99%E4%B8%99%E4%B8%81%E6%88%8A%E5%B7%B1%E5%BA%9A%E8%BE%9B%E5%A3%AC%E7%99%B8%3C/text%3E%3Ctext%20x%3D%27232%27%20y%3D%2772%27%20font-size%3D%2720%27%3E%E5%AD%90%E4%B8%91%E5%AF%85%E5%8D%AF%E8%BE%B0%E5%B7%B3%E5%8D%88%E6%9C%AA%3C/text%3E%3Ctext%20x%3D%2728%27%20y%3D%27198%27%20font-size%3D%2718%27%3E%E7%94%B3%E9%85%89%E6%88%8C%E4%BA%A5%3C/text%3E%3Ctext%20x%3D%27300%27%20y%3D%27188%27%20font-size%3D%2716%27%20fill-opacity%3D%270.05%27%3E%E5%9B%9B%E6%9F%B1%3C/text%3E%3C/g%3E%3Cg%20transform%3D%27translate%28430%2C28%29%27%20fill%3D%27none%27%20stroke%3D%27%238eb0a4%27%20stroke-opacity%3D%270.07%27%20stroke-width%3D%270.8%27%3E%3Ccircle%20r%3D%2746%27/%3E%3Cpath%20d%3D%27M0-46a23%2023%200%200%201%200%2092a23%2023%200%200%201%200-46a23%2023%200%200%200%200-46z%27%20fill%3D%27%238eb0a4%27%20fill-opacity%3D%270.035%27/%3E%3C/g%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: 52% 45%;
  background-size: min(140%, 720px) auto;
  opacity: 0.42;
}

.hero-banner--bazhi > * {
  position: relative;
  z-index: 1;
}

.hero-banner--naming {
  border-color: rgba(216, 200, 150, 0.26);
  background: linear-gradient(145deg, rgba(90, 78, 42, 0.22) 0%, rgba(10, 9, 8, 0.94) 52%, rgba(18, 16, 14, 0.98) 100%);
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.32);
}
.hero-banner--naming .hero-module-icon {
  background: rgba(216, 200, 150, 0.08);
  border-color: rgba(216, 200, 150, 0.24);
  color: var(--mod-naming);
}
.hero-banner--naming h1 {
  color: #f5f0e4;
}

.hero-banner--zeliang {
  border-color: rgba(207, 168, 130, 0.26);
  background: linear-gradient(145deg, rgba(90, 62, 40, 0.22) 0%, rgba(10, 9, 8, 0.94) 52%, rgba(18, 16, 14, 0.98) 100%);
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.32);
}
.hero-banner--zeliang .hero-module-icon {
  background: rgba(207, 168, 130, 0.08);
  border-color: rgba(212, 180, 145, 0.24);
  color: var(--mod-zeliang);
}
.hero-banner--zeliang h1 {
  color: #f5ede6;
}

.hero-banner--xingzuo {
  border-color: rgba(154, 166, 184, 0.28);
  background: linear-gradient(145deg, rgba(52, 58, 68, 0.32) 0%, rgba(10, 9, 8, 0.94) 52%, rgba(18, 16, 14, 0.98) 100%);
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.32);
}
.hero-banner--xingzuo .hero-module-icon {
  background: rgba(154, 166, 184, 0.1);
  border-color: rgba(170, 180, 198, 0.26);
  color: var(--mod-xingzuo);
}
.hero-banner--xingzuo h1 {
  color: #e8eaee;
}

.hero-banner--mingzi {
  border-color: rgba(184, 160, 212, 0.28);
  background: linear-gradient(145deg, rgba(79, 63, 104, 0.32) 0%, rgba(10, 9, 8, 0.94) 52%, rgba(18, 16, 14, 0.98) 100%);
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.32);
}
.hero-banner--mingzi .hero-module-icon {
  background: rgba(184, 160, 212, 0.1);
  border-color: rgba(200, 180, 220, 0.26);
  color: var(--mod-mingzi);
}
.hero-banner--mingzi h1 {
  color: #eee8f5;
}

.hero-banner--zhougong {
  border-color: rgba(140, 170, 210, 0.3);
  background: linear-gradient(145deg, rgba(63, 85, 104, 0.34) 0%, rgba(10, 9, 8, 0.94) 52%, rgba(18, 16, 14, 0.98) 100%);
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.32);
}
.hero-banner--zhougong .hero-module-icon {
  background: rgba(156, 184, 216, 0.1);
  border-color: rgba(170, 195, 225, 0.26);
  color: var(--mod-dream);
}
.hero-banner--zhougong h1 {
  color: #e8eef6;
}

.muted {
  color: var(--muted);
  font-size: 0.92rem;
}

.grid-cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(248px, 1fr));
  gap: 1.25rem;
  margin-top: 0;
  width: 100%;
  box-sizing: border-box;
}

/* 首页：Banner 与功能卡片同宽、左右对齐 */
main.wrap > .hero-panel,
main.wrap > .grid-cards {
  width: 100%;
  max-width: 100%;
  margin-left: auto;
  margin-right: auto;
  box-sizing: border-box;
}

.card {
  position: relative;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 1.35rem 1.28rem 1.25rem;
  overflow: hidden;
  transition: transform 0.22s ease, box-shadow 0.22s ease, border-color 0.22s ease, background 0.22s ease;
}

a.card {
  display: block;
  text-decoration: none;
  color: inherit;
  cursor: pointer;
}

a.card:visited {
  color: inherit;
}

.card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, rgba(196, 165, 116, 0.22), transparent);
  opacity: 0.9;
}

.card:hover {
  transform: translateY(-3px);
  border-color: var(--border-strong);
  background: var(--card-hover);
  box-shadow: var(--shadow-md);
}

a.card {
  display: block;
  text-decoration: none;
  color: inherit;
  cursor: pointer;
}

a.card:hover,
a.card:focus-visible {
  color: inherit;
}

.card-icon {
  width: 2.65rem;
  height: 2.65rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-sm);
  margin-bottom: 0.85rem;
  background: rgba(196, 165, 116, 0.08);
  border: 1px solid rgba(200, 175, 130, 0.18);
  color: var(--accent);
}

.card-icon .icon-svg {
  width: 1.65rem;
  height: 1.65rem;
}

.card h2 {
  margin: 0 0 0.5rem;
  font-family: var(--font-serif);
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--fg);
  letter-spacing: 0.04em;
}

.card p {
  margin: 0 0 1rem;
  color: rgba(210, 202, 190, 0.9);
  font-size: 0.93rem;
  line-height: 1.58;
}

/* 功能卡片：五行意象色，低对比铺底 */
.card--bazhi {
  background: linear-gradient(160deg, rgba(142, 176, 164, 0.06) 0%, rgba(18, 16, 14, 0.96) 48%, var(--card) 100%);
  border-color: rgba(142, 176, 164, 0.2);
}
.card--bazhi::before {
  height: 3px;
  background: linear-gradient(90deg, var(--mod-bazhi-deep), var(--mod-bazhi-mid));
  opacity: 0.85;
}
.card--bazhi .card-icon {
  background: rgba(142, 176, 164, 0.09);
  border-color: rgba(142, 176, 164, 0.2);
  color: var(--mod-bazhi);
}
.card--bazhi h2 {
  color: var(--fg);
}
.card--bazhi .btn-primary {
  background: linear-gradient(145deg, rgba(142, 176, 164, 0.22), rgba(61, 82, 72, 0.35));
  border-color: rgba(142, 176, 164, 0.28);
  color: var(--fg);
  font-weight: 650;
}
.card--bazhi .btn-primary:hover {
  background: linear-gradient(145deg, rgba(158, 190, 176, 0.32), rgba(61, 82, 72, 0.42));
  border-color: rgba(142, 176, 164, 0.4);
  color: #fff;
}

.card--naming {
  background: linear-gradient(160deg, rgba(216, 200, 150, 0.06) 0%, rgba(18, 16, 14, 0.96) 48%, var(--card) 100%);
  border-color: rgba(216, 200, 150, 0.2);
}
.card--naming::before {
  height: 3px;
  background: linear-gradient(90deg, var(--mod-naming-deep), var(--mod-naming-mid));
  opacity: 0.85;
}
.card--naming .card-icon {
  background: rgba(216, 200, 150, 0.08);
  border-color: rgba(216, 200, 150, 0.2);
  color: var(--mod-naming);
}
.card--naming h2 {
  color: var(--fg);
}
.card--naming .btn-primary {
  background: linear-gradient(145deg, rgba(216, 200, 150, 0.22), rgba(90, 78, 42, 0.32));
  border-color: rgba(216, 200, 150, 0.28);
  color: var(--fg);
  font-weight: 650;
}
.card--naming .btn-primary:hover {
  background: linear-gradient(145deg, rgba(228, 212, 168, 0.32), rgba(90, 78, 42, 0.4));
  border-color: rgba(216, 200, 150, 0.4);
  color: #fff;
}

.card--zeliang {
  background: linear-gradient(160deg, rgba(207, 168, 130, 0.06) 0%, rgba(18, 16, 14, 0.96) 48%, var(--card) 100%);
  border-color: rgba(207, 168, 130, 0.2);
}
.card--zeliang::before {
  height: 3px;
  background: linear-gradient(90deg, var(--mod-zeliang-deep), var(--mod-zeliang-mid));
  opacity: 0.85;
}
.card--zeliang .card-icon {
  background: rgba(207, 168, 130, 0.08);
  border-color: rgba(212, 180, 145, 0.2);
  color: var(--mod-zeliang);
}
.card--zeliang h2 {
  color: var(--fg);
}
.card--zeliang .btn-primary {
  background: linear-gradient(145deg, rgba(207, 168, 130, 0.22), rgba(90, 62, 40, 0.32));
  border-color: rgba(212, 180, 145, 0.28);
  color: var(--fg);
  font-weight: 650;
}
.card--zeliang .btn-primary:hover {
  background: linear-gradient(145deg, rgba(220, 182, 145, 0.32), rgba(90, 62, 40, 0.4));
  border-color: rgba(212, 180, 145, 0.4);
  color: #fff;
}

.card--xingzuo {
  background: linear-gradient(160deg, rgba(154, 166, 184, 0.07) 0%, rgba(18, 16, 14, 0.96) 48%, var(--card) 100%);
  border-color: rgba(154, 166, 184, 0.22);
}
.card--xingzuo::before {
  height: 3px;
  background: linear-gradient(90deg, var(--mod-xingzuo-deep), var(--mod-xingzuo-mid));
  opacity: 0.85;
}
.card--xingzuo .card-icon {
  background: rgba(154, 166, 184, 0.09);
  border-color: rgba(170, 180, 198, 0.22);
  color: var(--mod-xingzuo);
}
.card--xingzuo h2 {
  color: var(--fg);
}
.card--xingzuo .btn-primary {
  background: linear-gradient(145deg, rgba(154, 166, 184, 0.22), rgba(52, 58, 68, 0.38));
  border-color: rgba(170, 180, 198, 0.28);
  color: var(--fg);
  font-weight: 650;
}
.card--xingzuo .btn-primary:hover {
  background: linear-gradient(145deg, rgba(176, 186, 202, 0.32), rgba(52, 58, 68, 0.48));
  border-color: rgba(170, 180, 198, 0.4);
  color: #fff;
}

.card--mingzi {
  background: linear-gradient(160deg, rgba(184, 160, 212, 0.07) 0%, rgba(18, 16, 14, 0.96) 48%, var(--card) 100%);
  border-color: rgba(184, 160, 212, 0.24);
}
.card--mingzi::before {
  height: 3px;
  background: linear-gradient(90deg, var(--mod-mingzi-deep), var(--mod-mingzi-mid));
  opacity: 0.85;
}
.card--mingzi .card-icon {
  background: rgba(184, 160, 212, 0.09);
  border-color: rgba(200, 180, 220, 0.22);
  color: var(--mod-mingzi);
}
.card--mingzi .btn-primary {
  background: linear-gradient(145deg, rgba(184, 160, 212, 0.22), rgba(79, 63, 104, 0.35));
  border-color: rgba(200, 180, 220, 0.28);
  color: var(--fg);
  font-weight: 650;
}
.card--mingzi .btn-primary:hover {
  background: linear-gradient(145deg, rgba(200, 180, 228, 0.32), rgba(79, 63, 104, 0.45));
  border-color: rgba(200, 180, 220, 0.4);
  color: #fff;
}

.card--dream {
  background: linear-gradient(160deg, rgba(156, 184, 216, 0.07) 0%, rgba(18, 16, 14, 0.96) 48%, var(--card) 100%);
  border-color: rgba(156, 184, 216, 0.26);
}
.card--dream::before {
  height: 3px;
  background: linear-gradient(90deg, var(--mod-dream-deep), var(--mod-dream-mid));
  opacity: 0.85;
}
.card--dream .card-icon {
  background: rgba(156, 184, 216, 0.09);
  border-color: rgba(170, 195, 225, 0.24);
  color: var(--mod-dream);
}
.card--dream .btn-primary {
  background: linear-gradient(145deg, rgba(156, 184, 216, 0.22), rgba(63, 85, 104, 0.36));
  border-color: rgba(170, 195, 225, 0.28);
  color: var(--fg);
  font-weight: 650;
}
.card--dream .btn-primary:hover {
  background: linear-gradient(145deg, rgba(176, 200, 228, 0.32), rgba(63, 85, 104, 0.46));
  border-color: rgba(170, 195, 225, 0.4);
  color: #fff;
}

@keyframes cta-arrow-enter {
  0% {
    opacity: 0;
    transform: translateX(-0.28em);
  }
  65% {
    opacity: 1;
    transform: translateX(0.12em);
  }
  100% {
    opacity: 0.85;
    transform: translateX(0);
  }
}

/* 首页功能入口：整张卡片可点；「进入」下划线不含箭头（箭头为 ::after） */
.grid-cards a.card .btn-primary.card-cta {
  margin-top: 0.15rem;
  padding: 0.35rem 0;
  align-self: flex-start;
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  border: none;
  box-shadow: none;
  background: transparent !important;
  font-weight: 500;
  text-decoration: none;
  transition: color 0.2s ease;
}
.grid-cards a.card .card-cta__label {
  text-decoration: underline transparent;
  text-decoration-thickness: 1px;
  text-underline-offset: 0.28em;
  transition: text-decoration-color 0.2s ease, color 0.2s ease;
}
.grid-cards a.card .btn-primary.card-cta::after {
  content: "\2192";
  display: inline-block;
  font-size: 0.92em;
  line-height: 1;
  opacity: 0.85;
  transform: translateX(0);
  text-decoration: none;
  animation: cta-arrow-enter 0.7s cubic-bezier(0.22, 1, 0.36, 1) both;
  transition: transform 0.45s cubic-bezier(0.22, 1, 0.36, 1), opacity 0.25s ease;
}
.grid-cards a.card:hover .btn-primary.card-cta {
  border: none;
  box-shadow: none;
  background: transparent !important;
  text-decoration: none;
}
.grid-cards a.card:hover .card-cta__label {
  text-decoration-color: currentColor;
}
.grid-cards a.card:hover .btn-primary.card-cta::after {
  transform: translateX(0.42em);
  opacity: 1;
}
.grid-cards a.card:focus-visible .card-cta__label {
  text-decoration-color: currentColor;
}
.grid-cards a.card:focus-visible .btn-primary.card-cta::after {
  transform: translateX(0.42em);
  opacity: 1;
}
.grid-cards a.card--bazhi .btn-primary.card-cta {
  color: var(--mod-bazhi);
}
.grid-cards a.card--bazhi:hover .btn-primary.card-cta,
.grid-cards a.card--bazhi:hover .card-cta__label {
  color: #e2f0ea;
}
.grid-cards a.card--naming .btn-primary.card-cta {
  color: var(--mod-naming);
}
.grid-cards a.card--naming:hover .btn-primary.card-cta,
.grid-cards a.card--naming:hover .card-cta__label {
  color: #f5ecd4;
}
.grid-cards a.card--zeliang .btn-primary.card-cta {
  color: var(--mod-zeliang);
}
.grid-cards a.card--zeliang:hover .btn-primary.card-cta,
.grid-cards a.card--zeliang:hover .card-cta__label {
  color: #f5e8dc;
}
.grid-cards a.card--xingzuo .btn-primary.card-cta {
  color: var(--mod-xingzuo);
}
.grid-cards a.card--xingzuo:hover .btn-primary.card-cta,
.grid-cards a.card--xingzuo:hover .card-cta__label {
  color: #eef1f6;
}
.grid-cards a.card--mingzi .btn-primary.card-cta {
  color: var(--mod-mingzi);
}
.grid-cards a.card--mingzi:hover .btn-primary.card-cta,
.grid-cards a.card--mingzi:hover .card-cta__label {
  color: #eee8f5;
}
.grid-cards a.card--dream .btn-primary.card-cta {
  color: var(--mod-dream);
}
.grid-cards a.card--dream:hover .btn-primary.card-cta,
.grid-cards a.card--dream:hover .card-cta__label {
  color: #e8eef6;
}

@media (prefers-reduced-motion: reduce) {
  .grid-cards a.card .btn-primary.card-cta::after {
    animation: none;
    opacity: 0.85;
    transform: none;
  }

  .grid-cards a.card .btn-primary.card-cta::after,
  .grid-cards a.card:hover .btn-primary.card-cta::after {
    transition: none;
    transform: none;
  }
}

.hero-banner .muted {
  color: rgba(210, 200, 186, 0.88);
}

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.35rem;
  padding: 0.5rem 1rem;
  border-radius: var(--radius-sm);
  border: 1px solid var(--border);
  background: rgba(255, 255, 255, 0.05);
  color: var(--fg-soft);
  font-size: 0.88rem;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.18s ease, border-color 0.18s ease, color 0.18s ease, transform 0.12s ease;
}

.btn:hover {
  color: var(--fg);
  background: rgba(255, 255, 255, 0.1);
  border-color: var(--border-strong);
  text-decoration: none;
}

.btn:active {
  transform: scale(0.98);
}

.btn-primary {
  background: linear-gradient(145deg, rgba(180, 150, 100, 0.28), rgba(72, 62, 48, 0.4));
  border-color: rgba(200, 175, 130, 0.32);
  color: var(--fg);
}

.btn-primary:hover {
  background: linear-gradient(145deg, rgba(200, 175, 128, 0.36), rgba(82, 70, 52, 0.45));
  border-color: rgba(220, 200, 150, 0.42);
  color: #fdf8f0;
}

form.fortune-form {
  margin-top: 0;
  margin-left: auto;
  margin-right: auto;
  display: grid;
  gap: 0.85rem;
  width: 100%;
  max-width: min(var(--content-column), 100%);
  box-sizing: border-box;
  padding: 1.25rem 1.2rem;
  border-radius: var(--radius);
  border: 1px solid var(--border);
  background: linear-gradient(175deg, rgba(28, 24, 20, 0.65) 0%, rgba(12, 11, 10, 0.92) 100%);
  box-shadow: var(--shadow-sm);
}

form.fortune-form label {
  display: grid;
  gap: 0.35rem;
  font-size: 0.88rem;
  color: var(--fg-soft);
}

input,
select,
textarea {
  width: 100%;
  padding: 0.55rem 0.65rem;
  border-radius: var(--radius-sm);
  border: 1px solid var(--border);
  background: rgba(0, 0, 0, 0.35);
  color: var(--fg);
  font-family: inherit;
  font-size: 0.95rem;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

input:hover,
select:hover,
textarea:hover {
  border-color: rgba(255, 255, 255, 0.18);
}

input:focus,
select:focus,
textarea:focus {
  border-color: rgba(196, 165, 116, 0.48);
  box-shadow: 0 0 0 3px rgba(196, 165, 116, 0.1);
  outline: none;
}

textarea {
  min-height: 4.5rem;
  resize: vertical;
}

.form-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
  margin-top: 0.25rem;
}

.form-error {
  margin: 0;
  padding: 0.55rem 0.75rem;
  border-radius: var(--radius-sm);
  border: 1px solid rgba(200, 90, 72, 0.4);
  background: rgba(60, 22, 18, 0.35);
  color: #f0c8c0;
  font-size: 0.88rem;
}

form.fortune-form fieldset.fortune-form__fieldset {
  margin: 0;
  padding: 0.65rem 0.85rem;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
}

form.fortune-form fieldset.fortune-form__fieldset legend {
  padding: 0 0.35rem;
  font-size: 0.88rem;
  color: var(--fg-soft);
}

form.fortune-form .fortune-form__inline-row {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem 1.5rem;
}

form.fortune-form .fortune-form__inline-row label {
  display: inline-flex;
  flex-direction: row;
  align-items: center;
  gap: 0.45rem;
  width: auto;
}

form.fortune-form .fortune-form__inline-row input[type="radio"] {
  width: auto;
  margin: 0;
}

form.fortune-form .fortune-form__note {
  margin: 0.5rem 0 0;
  font-size: 0.82rem;
}

/* 出生时间：date + time 分栏，保留右侧原生图标 */
.birth-datetime {
  display: grid;
  gap: 0.65rem;
}
.birth-datetime__grid {
  display: grid;
  grid-template-columns: 1.15fr 0.85fr;
  gap: 0.75rem;
}
@media (max-width: 520px) {
  .birth-datetime__grid {
    grid-template-columns: 1fr;
  }
}
.birth-datetime__cell {
  display: grid;
  gap: 0.4rem;
  margin: 0;
  cursor: pointer;
}
.birth-datetime__cell-label {
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--fg-soft);
  cursor: pointer;
}
.birth-datetime__field {
  position: relative;
  display: block;
  width: 100%;
  cursor: pointer;
}
.birth-datetime__picker {
  width: 100%;
  min-height: 3rem;
  padding: 0.7rem 2.75rem 0.7rem 0.85rem;
  font-size: 1.02rem;
  color-scheme: dark;
  cursor: pointer;
}
/* 保留右侧日历/时钟图标，并加大可点区域 */
.birth-datetime__picker::-webkit-calendar-picker-indicator {
  cursor: pointer;
  opacity: 0.92;
  width: 1.35rem;
  height: 1.35rem;
  margin: 0;
  padding: 0.2rem;
  filter: invert(0.82) sepia(0.28) saturate(1.35) hue-rotate(5deg);
}
.birth-datetime__picker--time::-webkit-calendar-picker-indicator {
  filter: invert(0.78) sepia(0.2) saturate(1.2) hue-rotate(180deg);
}
.birth-datetime__summary {
  margin: 0;
  padding: 0.55rem 0.75rem;
  border-radius: var(--radius-sm);
  border: 1px solid rgba(196, 165, 116, 0.22);
  background: rgba(196, 165, 116, 0.08);
  color: var(--accent-strong);
  font-size: 0.95rem;
  letter-spacing: 0.04em;
  line-height: 1.5;
}
.birth-datetime__summary[hidden] {
  display: none;
}
.birth-datetime__hint {
  margin: 0;
  font-size: 0.82rem;
  line-height: 1.65;
}
.birth-datetime input[type="hidden"] {
  position: absolute;
  width: 1px;
  height: 1px;
  opacity: 0;
  pointer-events: none;
}

.result-block {
  margin-top: 1.25rem;
  padding: 1.2rem 1.25rem;
  border-radius: var(--radius);
  border: 1px solid var(--border);
  background: linear-gradient(165deg, rgba(22, 20, 18, 0.75) 0%, rgba(12, 11, 10, 0.92) 100%);
  box-shadow: var(--shadow-sm);
}
.result-block h2 {
  margin-top: 0;
  font-size: 1.12rem;
  color: var(--fg-soft);
}
.result-block h2.jieguo-card__title {
  font-size: 1.28rem;
  color: var(--accent-strong);
  letter-spacing: 0.12em;
}

.pay-box {
  margin-top: 1.25rem;
  padding: 1.2rem 1.25rem;
  border-radius: var(--radius);
  border: 1px dashed rgba(232, 200, 114, 0.35);
  background: linear-gradient(145deg, rgba(232, 200, 114, 0.06) 0%, rgba(12, 11, 10, 0.92) 100%);
  box-shadow: var(--shadow-sm);
}
.pay-box h2 {
  color: var(--fg-soft);
}

.site-footer {
  border-top: 1px solid var(--border);
  margin-top: auto;
  padding: 1.75rem 0 2.25rem;
  font-size: 0.86rem;
  color: var(--muted);
  background: linear-gradient(0deg, rgba(5, 8, 16, 0.85) 0%, transparent 100%);
}

.site-footer .inner p {
  margin: 0.35rem 0;
}

.site-footer .inner p:first-child {
  margin-top: 0;
}

.site-footer__licenses {
  text-align: center;
  font-size: 0.82rem;
  letter-spacing: 0.02em;
}

.site-footer__license-link {
  color: inherit;
  text-decoration: none;
}

.site-footer__license-link:hover {
  color: var(--fg-soft);
  text-decoration: underline;
}

.site-footer__license-sep {
  opacity: 0.65;
}

@media (max-width: 520px) {
  .site-header .inner {
    flex-direction: column;
    align-items: stretch;
  }

  .nav {
    justify-content: center;
  }

  .hero {
    text-align: left;
    margin: 0;
    max-width: none;
  }

  .hero--module {
    align-items: flex-start;
    text-align: left;
  }

  .hero-panel .hero {
    padding: 1.5rem 1rem;
  }
}

/* —— 测算结果页（结构化展示 · 道教意象 · 五行 · 星座） —— */
body.jieguo-page {
  background-image:
    radial-gradient(ellipse 70% 40% at 50% -8%, rgba(120, 86, 48, 0.09), transparent 50%),
    radial-gradient(ellipse 50% 36% at 12% 22%, rgba(60, 90, 72, 0.08), transparent 45%),
    radial-gradient(ellipse 40% 30% at 88% 18%, rgba(70, 78, 110, 0.07), transparent 42%),
    repeating-linear-gradient(
      125deg,
      transparent,
      transparent 48px,
      rgba(196, 165, 116, 0.02) 48px,
      rgba(196, 165, 116, 0.02) 49px
    ),
    linear-gradient(180deg, #151210 0%, var(--bg-deep) 46%, #030302 100%);
}

.jieguo-hero {
  position: relative;
}
.jieguo-hero::before {
  content: "☯";
  position: absolute;
  right: clamp(0.5rem, 4vw, 2rem);
  top: 0.5rem;
  font-size: clamp(2rem, 5vw, 3.25rem);
  opacity: 0.07;
  pointer-events: none;
  font-family: var(--font-serif);
}
.jieguo-hero__lead {
  max-width: none;
  margin-left: auto;
  margin-right: auto;
}

/* 结果页：顶栏、报告、底部分栏统一列宽与左右对齐 */
.jieguo-reading {
  display: flex;
  flex-direction: column;
  align-items: stretch;
}

.jieguo-reading > .jieguo-hero,
.jieguo-reading > .result-block,
.jieguo-reading > .jieguo-result-ad {
  width: 100%;
  max-width: min(var(--content-column), 100%);
  margin-left: auto;
  margin-right: auto;
  box-sizing: border-box;
}

.jieguo-reading > .result-block {
  margin-top: 1rem;
}

.jieguo-reading .jieguo-card {
  padding: 1.5rem clamp(1.15rem, 4vw, 1.85rem) 2rem;
}

.jieguo-card {
  position: relative;
  overflow: hidden;
  border: 1px solid var(--border-strong);
  background:
    linear-gradient(165deg, rgba(26, 22, 18, 0.92) 0%, rgba(10, 9, 8, 0.97) 100%);
  box-shadow: var(--shadow-md), inset 0 1px 0 rgba(255, 248, 235, 0.04);
}
.jieguo-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 80% 50% at 50% 0%, rgba(196, 165, 116, 0.06), transparent 55%);
  pointer-events: none;
}
.jieguo-card--full {
  border-color: rgba(196, 165, 116, 0.28);
}

.jieguo-card__head {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 1.25rem;
  position: relative;
  z-index: 1;
  flex-wrap: wrap;
}
.jieguo-card__head--full {
  border-bottom: 1px solid var(--border);
  padding-bottom: 1rem;
  margin-bottom: 1.5rem;
}
.jieguo-card__title {
  margin: 0;
  font-family: var(--font-serif);
  font-size: 1.28rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  color: var(--accent-strong);
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0.35rem 0.65rem;
}

.jieguo-seal {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 2.75rem;
  padding: 0.2rem 0.45rem;
  border: 2px solid rgba(196, 90, 72, 0.55);
  color: rgba(232, 180, 160, 0.95);
  font-family: var(--font-serif);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.2em;
  transform: rotate(-4deg);
  border-radius: 3px;
  background: rgba(40, 22, 18, 0.65);
  box-shadow: inset 0 0 0 1px rgba(0, 0, 0, 0.35);
}
.jieguo-seal--full {
  border-color: rgba(196, 165, 116, 0.55);
  color: var(--gold);
}

.jieguo-tao-accent {
  height: 3px;
  margin: 0 0 1.25rem;
  border-radius: 2px;
  background: linear-gradient(
    90deg,
    rgba(90, 58, 48, 0.5),
    rgba(196, 165, 116, 0.65),
    rgba(70, 88, 78, 0.5)
  );
  position: relative;
  z-index: 1;
}
.jieguo-tao-accent--calendar {
  background: linear-gradient(90deg, rgba(120, 72, 48, 0.55), rgba(200, 150, 90, 0.7), rgba(90, 52, 40, 0.5));
}

.jieguo-meta-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 0.75rem 1.25rem;
  margin-bottom: 1.25rem;
  position: relative;
  z-index: 1;
}
.jieguo-meta__label {
  display: block;
  font-size: 0.72rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--muted2);
  margin-bottom: 0.2rem;
}
.jieguo-meta__val {
  font-family: var(--font-serif);
  font-size: 1.02rem;
  color: var(--fg);
}

.jieguo-pillar-spotlight {
  text-align: center;
  padding: 1.35rem 1rem;
  margin-bottom: 1rem;
  border-radius: var(--radius);
  border: 1px solid rgba(142, 176, 164, 0.28);
  background: linear-gradient(160deg, rgba(61, 82, 72, 0.35) 0%, rgba(18, 16, 14, 0.9) 100%);
  position: relative;
  z-index: 1;
}
.jieguo-pillar-spotlight__label {
  font-size: 0.75rem;
  letter-spacing: 0.28em;
  color: var(--mod-bazhi);
}
.jieguo-pillar-spotlight__han {
  font-family: var(--font-serif);
  font-size: clamp(2rem, 5vw, 2.75rem);
  font-weight: 800;
  letter-spacing: 0.35em;
  margin: 0.35rem 0 0.15rem;
  color: var(--accent-strong);
  text-shadow: 0 0 28px rgba(142, 176, 164, 0.25);
}
.jieguo-pillar-spotlight__nayin {
  font-size: 0.95rem;
  color: var(--mod-bazhi-mid);
  letter-spacing: 0.12em;
}

.jieguo-pillar-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0.65rem;
  margin-bottom: 1.5rem;
  position: relative;
  z-index: 1;
}
@media (max-width: 720px) {
  .jieguo-pillar-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
.jieguo-pillar-cell {
  text-align: center;
  padding: 0.85rem 0.5rem;
  border-radius: var(--radius-sm);
  border: 1px solid rgba(142, 176, 164, 0.2);
  background: rgba(10, 12, 14, 0.55);
}
.jieguo-pillar-cell__pos {
  font-size: 0.7rem;
  letter-spacing: 0.2em;
  color: var(--muted);
}
.jieguo-pillar-cell__gz {
  font-family: var(--font-serif);
  font-size: 1.35rem;
  font-weight: 700;
  margin: 0.35rem 0 0.2rem;
  letter-spacing: 0.15em;
  color: var(--fg);
}
.jieguo-pillar-cell__ny {
  font-size: 0.8rem;
  color: var(--mod-bazhi);
}

.jieguo-teaser {
  margin: 0;
  padding: 1rem 1.15rem;
  border-left: 3px solid rgba(196, 165, 116, 0.55);
  background: rgba(0, 0, 0, 0.22);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
  color: var(--fg-soft);
  line-height: 1.9;
  font-size: 1.0625rem;
  position: relative;
  z-index: 1;
}

.jieguo-purpose {
  margin: 0 0 1rem;
  position: relative;
  z-index: 1;
}
.jieguo-purpose__label {
  display: inline-block;
  margin-right: 0.5rem;
  font-size: 0.75rem;
  letter-spacing: 0.2em;
  color: var(--muted2);
}

.jieguo-date-cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 0.75rem;
  margin-bottom: 1rem;
  position: relative;
  z-index: 1;
}
.jieguo-date-card {
  display: flex;
  align-items: stretch;
  gap: 0.85rem;
  padding: 0.85rem 1rem;
  border-radius: var(--radius-sm);
  border: 1px solid rgba(200, 150, 100, 0.25);
  background: linear-gradient(135deg, rgba(110, 74, 48, 0.2) 0%, rgba(12, 11, 10, 0.85) 100%);
}
.jieguo-date-card__score {
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 2.75rem;
  font-family: var(--font-serif);
  font-size: 1.35rem;
  font-weight: 800;
  color: var(--gold);
  border-right: 1px solid rgba(220, 200, 170, 0.12);
  padding-right: 0.85rem;
}
.jieguo-date-card__ymd {
  font-weight: 600;
  letter-spacing: 0.06em;
}
.jieguo-date-card__lunar {
  font-size: 0.86rem;
  margin-top: 0.2rem;
}

.jieguo-wuxing-strip {
  display: flex;
  justify-content: center;
  gap: 0.45rem;
  flex-wrap: wrap;
  margin-bottom: 1.15rem;
  position: relative;
  z-index: 1;
}
.wx-chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.1rem;
  height: 2.1rem;
  border-radius: 50%;
  font-family: var(--font-serif);
  font-weight: 800;
  font-size: 0.95rem;
  border: 2px solid rgba(255, 255, 255, 0.08);
  box-shadow: 0 4px 14px rgba(0, 0, 0, 0.35);
}
.wx-chip--mu {
  background: linear-gradient(145deg, #3d8f6a, #1e4a38);
  color: #d8f0e4;
}
.wx-chip--huo {
  background: linear-gradient(145deg, #c45c3e, #7a2818);
  color: #ffe8e0;
}
.wx-chip--tu {
  background: linear-gradient(145deg, #a88a48, #5c4a24);
  color: #fff6dc;
}
.wx-chip--jin {
  background: linear-gradient(145deg, #7a8294, #3e4452);
  color: #eef1f8;
}
.wx-chip--shui {
  background: linear-gradient(145deg, #2a5a8a, #142c48);
  color: #e0f0ff;
}

.jieguo-surname-line {
  margin: 0 0 0.85rem;
  position: relative;
  z-index: 1;
}
.jieguo-surname {
  font-family: var(--font-serif);
  font-size: 1.85rem;
  font-weight: 800;
  letter-spacing: 0.35em;
  margin-left: 0.35rem;
  color: var(--gold);
}

.jieguo-weak-row {
  margin: 0 0 1rem;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem;
  position: relative;
  z-index: 1;
}

.wx-pill {
  display: inline-flex;
  align-items: center;
  padding: 0.28rem 0.65rem;
  border-radius: 999px;
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  border: 1px solid rgba(255, 255, 255, 0.1);
}
.wx-pill--small {
  font-size: 0.78rem;
  padding: 0.2rem 0.5rem;
}
.wx-pill--tiny {
  font-size: 0.72rem;
  padding: 0.12rem 0.42rem;
}
.wx-pill--木,
.wx-pill--mu {
  background: rgba(61, 143, 106, 0.35);
  color: #c5ebd8;
  border-color: rgba(142, 176, 164, 0.45);
}
.wx-pill--火,
.wx-pill--huo {
  background: rgba(196, 92, 62, 0.35);
  color: #ffd4c8;
  border-color: rgba(232, 140, 110, 0.4);
}
.wx-pill--土,
.wx-pill--tu {
  background: rgba(168, 138, 72, 0.38);
  color: #fff2cc;
  border-color: rgba(216, 200, 150, 0.35);
}
.wx-pill--金,
.wx-pill--jin {
  background: rgba(122, 130, 148, 0.35);
  color: #e8ecf5;
  border-color: rgba(170, 180, 198, 0.4);
}
.wx-pill--水,
.wx-pill--shui {
  background: rgba(42, 90, 138, 0.38);
  color: #d0e8ff;
  border-color: rgba(100, 150, 200, 0.35);
}

.jieguo-name-samples {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 0.75rem;
  margin-bottom: 0.5rem;
  position: relative;
  z-index: 1;
}
.jieguo-name-card {
  padding: 1rem 1.1rem;
  border-radius: var(--radius-sm);
  border: 1px solid rgba(216, 200, 150, 0.22);
  background: rgba(18, 16, 14, 0.75);
}
.jieguo-name-card__full {
  font-family: var(--font-serif);
  font-size: 1.35rem;
  font-weight: 700;
  letter-spacing: 0.2em;
  margin-bottom: 0.45rem;
}

.jieguo-sign-hero {
  text-align: center;
  padding: 1rem 0 1.25rem;
  position: relative;
  z-index: 1;
}
.jieguo-sign-hero--large {
  padding: 1.25rem 0 1.5rem;
}
.jieguo-sign-ring {
  width: 5.5rem;
  height: 5.5rem;
  margin: 0 auto 0.75rem;
  border-radius: 50%;
  border: 2px solid rgba(154, 166, 184, 0.45);
  box-shadow:
    0 0 0 6px rgba(30, 36, 48, 0.85),
    0 0 40px rgba(120, 140, 180, 0.2),
    inset 0 0 24px rgba(80, 100, 140, 0.15);
  background: radial-gradient(circle at 35% 30%, rgba(200, 210, 230, 0.12), transparent 55%),
    radial-gradient(circle at 70% 75%, rgba(100, 120, 180, 0.15), transparent 50%),
    linear-gradient(165deg, #1a2230 0%, #0e1018 100%);
  display: flex;
  align-items: center;
  justify-content: center;
}
.jieguo-sign-star {
  font-size: 1.65rem;
  color: rgba(220, 200, 140, 0.9);
  text-shadow: 0 0 18px rgba(220, 200, 140, 0.45);
}
.jieguo-sign-name {
  font-family: var(--font-serif);
  font-size: clamp(1.5rem, 4vw, 2rem);
  font-weight: 800;
  letter-spacing: 0.25em;
  color: #e4eaf5;
}
.jieguo-sign-sub {
  font-size: 0.8rem;
  color: var(--mod-xingzuo);
  letter-spacing: 0.2em;
  margin-top: 0.35rem;
}
.jieguo-overview {
  margin: 0 0 1.15rem;
  line-height: 1.9;
  font-size: 1.0625rem;
  color: var(--fg-soft);
  position: relative;
  z-index: 1;
}

.jieguo-prose-block {
  margin-bottom: 1.25rem;
  position: relative;
  z-index: 1;
}
.jieguo-prose-block__h {
  margin: 0 0 0.65rem;
  font-family: var(--font-serif);
  font-size: 1.125rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  line-height: 1.55;
  color: var(--mod-bazhi);
  text-indent: 0;
}
.jieguo-prose-block p {
  margin: 0 0 0.85em;
  color: var(--fg-soft);
  line-height: 1.9;
  font-size: 1.0625rem;
  letter-spacing: 0.02em;
}
.jieguo-prose-block p:last-child {
  margin-bottom: 0;
}

/* 结果正文：中文排版（首行缩进、两端对齐、适中间距） */
.jieguo-reading .jieguo-card--full .jieguo-prose-block p,
.jieguo-reading .jieguo-card--full .jieguo-overview,
.jieguo-reading .jieguo-card--full .jieguo-teaser,
.jieguo-reading .jieguo-card--locked .jieguo-prose-block:not(.jieguo-prose-block--in-lock) > p,
.jieguo-reading .jieguo-card--locked .jieguo-bazi-seg .jieguo-prose-block > p {
  text-indent: 2em;
  text-align: justify;
  text-justify: inter-ideograph;
  word-break: break-word;
  hyphens: none;
}
.jieguo-reading .jieguo-dream-snippet {
  font-size: 1.0625rem;
  line-height: 2;
  text-indent: 2em;
  text-align: justify;
  text-justify: inter-ideograph;
  padding: 1rem 1.2rem;
  margin-bottom: 1.1rem;
}
.jieguo-reading .jieguo-teaser {
  font-size: 1.0625rem;
  line-height: 2;
  padding: 1rem 1.2rem 1rem 1.35rem;
}
.jieguo-reading .jieguo-bazi-lock-zone__hint,
.jieguo-reading .jieguo-meta__val,
.jieguo-reading .jieguo-pillar-cell__gz,
.jieguo-reading .jieguo-pillar-cell__ny,
.jieguo-reading .jieguo-name-score-hero,
.jieguo-reading .jieguo-cal-row__date,
.jieguo-reading .jieguo-purpose {
  text-indent: 0;
  text-align: inherit;
}
.jieguo-prose-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 1rem;
}

/* 八字预览 / 完整报告：模块分割 */
.jieguo-bazi-seg {
  margin-bottom: 1rem;
  padding: 1rem 1.15rem;
  border: 1px solid rgba(200, 160, 110, 0.22);
  border-radius: var(--radius-sm);
  background: rgba(12, 10, 9, 0.42);
  position: relative;
  z-index: 1;
}
.jieguo-meta-grid.jieguo-bazi-seg {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(12rem, 1fr));
  gap: 0.75rem 1.25rem;
}
.jieguo-pillar-cell--day {
  border-color: rgba(196, 165, 116, 0.45);
  box-shadow: inset 0 0 0 1px rgba(232, 210, 170, 0.12);
}
.jieguo-pillar-cell--day .jieguo-pillar-cell__pos {
  color: var(--gold);
}

/* 预览态：命局分析起全文入 DOM，正文 2.5 行可读后缓渐隐遮罩 */
.jieguo-bazi-lock-zone {
  --bazi-lock-line: calc(1.0625rem * 1.9);
  --bazi-lock-head: calc(0.85rem + 1rem + 0.45rem + 0.2rem);
  --bazi-lock-clear: calc(var(--bazi-lock-head) + var(--bazi-lock-line) * 2.5);
  --bazi-lock-solid: calc(var(--bazi-lock-clear) + var(--bazi-lock-line) * 3);
  position: relative;
  margin-top: 0.75rem;
  border: 1px solid rgba(200, 160, 110, 0.24);
  border-radius: var(--radius-sm);
  background: rgb(8, 7, 6);
  overflow: hidden;
}
.jieguo-bazi-lock-zone__content {
  padding: 0.85rem 1.1rem 1rem;
}
.jieguo-prose-block--in-lock {
  margin-bottom: 0.65rem;
  padding: 0;
  border: none;
  background: transparent;
}
.jieguo-prose-block--in-lock:last-child {
  margin-bottom: 0;
}
.jieguo-prose-block--in-lock p {
  margin: 0.2rem 0 0;
  line-height: 1.9;
  color: var(--fg-soft);
  font-size: 1.0625rem;
  letter-spacing: 0.02em;
}
.jieguo-reading .jieguo-prose-block--in-lock p {
  text-indent: 2em;
  text-align: justify;
  text-justify: inter-ideograph;
}
.jieguo-bazi-lock-zone__veil {
  position: absolute;
  inset: 0;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
  /* 标题 + 正文恰好 2.5 行清晰，再以约 3 行行高缓渐隐 */
  background: linear-gradient(
    to bottom,
    rgba(8, 7, 6, 0) 0,
    rgba(8, 7, 6, 0) var(--bazi-lock-clear),
    rgba(8, 7, 6, 0.08) calc(var(--bazi-lock-clear) + var(--bazi-lock-line) * 0.6),
    rgba(8, 7, 6, 0.24) calc(var(--bazi-lock-clear) + var(--bazi-lock-line) * 1.2),
    rgba(8, 7, 6, 0.44) calc(var(--bazi-lock-clear) + var(--bazi-lock-line) * 1.8),
    rgba(8, 7, 6, 0.68) calc(var(--bazi-lock-clear) + var(--bazi-lock-line) * 2.4),
    rgba(8, 7, 6, 0.9) calc(var(--bazi-lock-clear) + var(--bazi-lock-line) * 2.85),
    rgb(8, 7, 6) var(--bazi-lock-solid),
    rgb(8, 7, 6) 100%
  );
}
.jieguo-bazi-lock-zone__veil::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: calc(var(--bazi-lock-clear) + var(--bazi-lock-line) * 0.4);
  bottom: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='168' height='96' viewBox='0 0 168 96'%3E%3Ctext x='6' y='52' fill='rgba(196%2C165%2C116%2C0.12)' font-family='Songti%20SC%2Cserif' font-size='12' letter-spacing='3' transform='rotate(-16%2084%2048)'%3E%E6%94%AF%E4%BB%98%E5%90%8E%E6%9F%A5%E7%9C%8B%3C/text%3E%3C/svg%3E"),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='80' viewBox='0 0 140 80'%3E%3Ctext x='4' y='44' fill='rgba(196%2C165%2C116%2C0.08)' font-family='Songti%20SC%2Cserif' font-size='11' letter-spacing='2' transform='rotate(-14%2070%2040)'%3E%E6%94%AF%E4%BB%98%E8%A7%A3%E9%94%81%3C/text%3E%3C/svg%3E");
  background-size: 168px 96px, 140px 80px;
  background-position: 0 0, 72px 40px;
  background-repeat: repeat;
  pointer-events: none;
}
.jieguo-bazi-lock-zone__stamp {
  position: relative;
  z-index: 1;
  margin-top: calc(var(--bazi-lock-clear) * 0.35);
  padding: 0.45rem 0.75rem;
  font-family: var(--font-serif);
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.32em;
  line-height: 1.5;
  color: rgba(232, 210, 170, 0.55);
  border: 1px solid rgba(196, 165, 116, 0.22);
  border-radius: 3px;
  background: rgba(20, 14, 10, 0.35);
  transform: rotate(-4deg);
  box-shadow: 0 4px 18px rgba(0, 0, 0, 0.35);
  pointer-events: none;
}
.jieguo-bazi-lock-zone__hint {
  position: relative;
  z-index: 3;
  margin: 0;
  padding: 0.45rem 0.85rem 0.65rem;
  text-align: center;
  font-size: 0.66rem;
  line-height: 1.65;
  letter-spacing: 0.1em;
  color: var(--muted2);
  background: rgb(8, 7, 6);
}
.jieguo-bazi-lock-zone__hint-note {
  display: block;
  margin-top: 0.2rem;
  font-size: 0.6rem;
  letter-spacing: 0.08em;
  color: rgba(160, 145, 125, 0.85);
}

.jieguo-prose-grid--bazi-full {
  gap: 1rem;
}
.jieguo-prose-grid--bazi-full .jieguo-prose-block {
  margin-bottom: 0;
}

.jieguo-calendar {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  position: relative;
  z-index: 1;
}
.jieguo-cal-row {
  padding: 1rem 1.1rem;
  border-radius: var(--radius-sm);
  border: 1px solid rgba(200, 160, 110, 0.2);
  background: rgba(12, 10, 9, 0.65);
}
.jieguo-cal-row__head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.75rem;
}
.jieguo-cal-row__date {
  font-family: var(--font-serif);
  font-weight: 700;
  letter-spacing: 0.08em;
}
.jieguo-cal-row__score {
  font-weight: 800;
  color: var(--gold);
  font-size: 1.1rem;
}
.jieguo-cal-row__lunar {
  font-size: 0.86rem;
  margin: 0.25rem 0 0.65rem;
}
.jieguo-cal-row__tags {
  display: flex;
  gap: 0.45rem;
  align-items: flex-start;
  margin-top: 0.35rem;
  font-size: 0.88rem;
  line-height: 1.55;
}
.jieguo-tag {
  flex-shrink: 0;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.15em;
  padding: 0.12rem 0.35rem;
  border-radius: 4px;
}
.jieguo-tag--yi {
  background: rgba(90, 120, 88, 0.45);
  color: #d8f0d4;
  border: 1px solid rgba(120, 160, 110, 0.4);
}
.jieguo-tag--ji {
  background: rgba(120, 58, 52, 0.45);
  color: #ffd8d4;
  border: 1px solid rgba(180, 90, 80, 0.35);
}
.jieguo-tagline {
  color: var(--fg-soft);
}
.jieguo-cal-row__note {
  margin: 0.65rem 0 0;
  font-size: 0.88rem;
  color: var(--muted);
}

.jieguo-wx-bars {
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
  margin-bottom: 1rem;
  max-width: 28rem;
  position: relative;
  z-index: 1;
}
.jieguo-wx-bar__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 0.2rem;
}
.jieguo-wx-bar__n {
  font-size: 0.85rem;
  color: var(--muted);
}
.jieguo-wx-bar__track {
  height: 6px;
  border-radius: 999px;
  background: rgba(0, 0, 0, 0.35);
  overflow: hidden;
}
.jieguo-wx-bar__fill {
  height: 100%;
  border-radius: 999px;
  transition: width 0.4s ease;
}
.wx-fill--木 {
  background: linear-gradient(90deg, #2d6a4f, #5cb890);
}
.wx-fill--火 {
  background: linear-gradient(90deg, #8a3020, #e87850);
}
.wx-fill--土 {
  background: linear-gradient(90deg, #6a5428, #d4b870);
}
.wx-fill--金 {
  background: linear-gradient(90deg, #4a5060, #a8b0c8);
}
.wx-fill--水 {
  background: linear-gradient(90deg, #1a3a5c, #5090d0);
}

.jieguo-style-note {
  margin: 0 0 1rem;
  font-size: 0.92rem;
  color: var(--fg-soft);
  position: relative;
  z-index: 1;
}

.jieguo-name-list {
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
  position: relative;
  z-index: 1;
}
.jieguo-name-row {
  padding: 0.9rem 1rem;
  border-radius: var(--radius-sm);
  border: 1px solid rgba(200, 180, 130, 0.18);
  background: rgba(8, 8, 10, 0.5);
}
.jieguo-name-row__full {
  font-family: var(--font-serif);
  font-size: 1.15rem;
  font-weight: 700;
  letter-spacing: 0.15em;
}
.jieguo-name-row__meta {
  margin: 0.35rem 0;
}
.jieguo-name-row__mean {
  margin: 0;
  font-size: 0.9rem;
  color: var(--fg-soft);
  line-height: 1.65;
}

.jieguo-horo-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 0.85rem;
  position: relative;
  z-index: 1;
}
.jieguo-horo-tile {
  padding: 1rem 1.05rem;
  border-radius: var(--radius-sm);
  border: 1px solid rgba(120, 140, 170, 0.28);
  background: linear-gradient(155deg, rgba(40, 48, 62, 0.55) 0%, rgba(12, 12, 16, 0.92) 100%);
}
.jieguo-horo-tile__h {
  margin: 0 0 0.45rem;
  font-family: var(--font-serif);
  font-size: 0.95rem;
  letter-spacing: 0.2em;
  color: var(--mod-xingzuo-mid);
}
.jieguo-horo-tile p {
  margin: 0;
  font-size: 0.9rem;
  color: var(--fg-soft);
  line-height: 1.7;
}

.jieguo-footnote {
  margin: 1.25rem 0 0;
  font-size: 0.82rem;
  color: var(--muted);
  line-height: 1.65;
  position: relative;
  z-index: 1;
}

.jieguo-name-score-hero {
  text-align: center;
  margin-bottom: 1rem;
  position: relative;
  z-index: 1;
}
.jieguo-name-score-hero__name {
  font-family: var(--font-serif);
  font-size: clamp(1.35rem, 3.5vw, 1.75rem);
  font-weight: 700;
  letter-spacing: 0.12em;
  color: #eee8f5;
}
.jieguo-name-score-hero__score {
  margin-top: 0.35rem;
  font-size: 2rem;
  font-weight: 800;
  color: var(--mod-mingzi);
  font-family: var(--font-serif);
}
.jieguo-name-score-hero__sub {
  margin-top: 0.25rem;
  font-size: 0.82rem;
  color: var(--muted);
}

.jieguo-wuge-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.86rem;
  margin: 0.75rem 0 1rem;
  position: relative;
  z-index: 1;
}
.jieguo-wuge-table th,
.jieguo-wuge-table td {
  border: 1px solid rgba(196, 165, 116, 0.15);
  padding: 0.45rem 0.55rem;
  text-align: left;
}
.jieguo-wuge-table th {
  color: var(--muted2);
  font-weight: 600;
  background: rgba(0, 0, 0, 0.22);
}

.jieguo-char-line {
  margin: 0.5rem 0;
  padding: 0.55rem 0.65rem;
  border-radius: var(--radius-sm);
  border: 1px solid rgba(184, 160, 212, 0.2);
  background: rgba(0, 0, 0, 0.18);
  position: relative;
  z-index: 1;
}
.jieguo-char-line__han {
  font-size: 1.25rem;
  font-weight: 700;
  margin-right: 0.5rem;
  color: var(--mod-mingzi);
}

.jieguo-dream-snippet {
  font-size: 0.92rem;
  line-height: 1.65;
  color: var(--fg-soft);
  padding: 0.65rem 0.75rem;
  border-radius: var(--radius-sm);
  border: 1px dashed rgba(156, 184, 216, 0.35);
  background: rgba(0, 0, 0, 0.2);
  position: relative;
  z-index: 1;
}
.jieguo-dream-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  margin: 0.65rem 0 0.5rem;
  position: relative;
  z-index: 1;
}
.jieguo-dream-chip {
  display: inline-block;
  padding: 0.2rem 0.55rem;
  border-radius: 999px;
  font-size: 0.78rem;
  border: 1px solid rgba(156, 184, 216, 0.35);
  color: var(--mod-dream);
  background: rgba(63, 85, 104, 0.25);
}

.jieguo-pay {
  border-style: solid;
  border-width: 1px;
  border-color: rgba(196, 165, 116, 0.32);
  background: linear-gradient(160deg, rgba(40, 32, 22, 0.55) 0%, rgba(10, 9, 8, 0.94) 100%);
}
.jieguo-pay__title {
  margin-top: 0;
  font-family: var(--font-serif);
  letter-spacing: 0.12em;
}
.jieguo-pay__price strong {
  color: var(--gold);
  font-size: 1.15rem;
}
.jieguo-pay__label {
  display: block;
  font-size: 0.78rem;
  letter-spacing: 0.16em;
  color: var(--muted2);
  margin-bottom: 0.25rem;
}
.jieguo-pay__unit {
  margin-left: 0.15rem;
  font-size: 0.92rem;
  color: var(--fg-soft);
}
.jieguo-pay__sub {
  margin: 0.65rem 0 0;
  font-size: 0.82rem;
}
.jieguo-pay__hint {
  margin-bottom: 0;
  margin-top: 0.75rem;
}

.jieguo-pay__live {
  margin-top: 1.1rem;
}
.jieguo-pay__live-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
}
.jieguo-pay__live-btn {
  min-width: 8.5rem;
  text-align: center;
}
.jieguo-pay__live-btn--wx {
  background: linear-gradient(180deg, #1f9b4c 0%, #157a3a 100%);
  border-color: rgba(120, 220, 150, 0.35);
}
.jieguo-pay__live-btn--alipay {
  background: linear-gradient(180deg, #1677ff 0%, #0d5fd6 100%);
  border-color: rgba(120, 180, 255, 0.35);
}

.jieguo-pay__mock {
  margin-top: 1.25rem;
  padding-top: 1.1rem;
  border-top: 1px dashed rgba(196, 165, 116, 0.28);
}
.jieguo-pay__mock-caption {
  margin: 0 0 0.35rem;
  font-size: 0.8rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  color: rgba(232, 200, 114, 0.75);
}
.jieguo-pay__mock-hint {
  margin: 0 0 1rem;
  font-size: 0.82rem;
  line-height: 1.65;
}
.jieguo-pay .jieguo-pay__reveal.btn {
  margin-top: 0.35rem;
  position: relative;
  padding: 0.68rem 1.5rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  border-radius: 11px;
  border: 1px solid rgba(232, 210, 165, 0.42);
  color: #fdf8f0;
  background: linear-gradient(
    180deg,
    rgba(228, 200, 145, 0.55) 0%,
    rgba(155, 128, 82, 0.52) 38%,
    rgba(88, 72, 48, 0.78) 100%
  );
  box-shadow:
    0 1px 0 rgba(255, 252, 240, 0.22) inset,
    0 -1px 0 rgba(0, 0, 0, 0.28) inset,
    0 5px 0 rgba(28, 24, 18, 0.95),
    0 8px 22px rgba(0, 0, 0, 0.42);
  transform: translateY(0);
  transition: transform 0.14s ease, box-shadow 0.14s ease, filter 0.14s ease;
}
.jieguo-pay .jieguo-pay__reveal.btn:hover:not(:disabled) {
  color: #fdf8f0;
  filter: brightness(1.06);
  box-shadow:
    0 1px 0 rgba(255, 252, 240, 0.26) inset,
    0 -1px 0 rgba(0, 0, 0, 0.25) inset,
    0 5px 0 rgba(28, 24, 18, 0.95),
    0 10px 26px rgba(0, 0, 0, 0.48);
}
.jieguo-pay .jieguo-pay__reveal.btn:active:not(:disabled) {
  transform: translateY(4px);
  box-shadow:
    0 1px 0 rgba(255, 252, 240, 0.14) inset,
    0 2px 6px rgba(0, 0, 0, 0.45) inset,
    0 1px 0 rgba(28, 24, 18, 0.9),
    0 4px 14px rgba(0, 0, 0, 0.38);
}
.jieguo-pay .jieguo-pay__reveal.btn:disabled {
  opacity: 0.78;
  cursor: default;
  transform: translateY(3px);
  filter: saturate(0.92);
  box-shadow:
    0 1px 0 rgba(255, 252, 240, 0.12) inset,
    0 -1px 0 rgba(0, 0, 0, 0.35) inset,
    0 2px 0 rgba(28, 24, 18, 0.88),
    0 4px 14px rgba(0, 0, 0, 0.35);
}
.jieguo-pay__qr-panel {
  margin-top: 1rem;
}
.jieguo-pay__qr-single {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1rem;
  max-width: 320px;
  margin: 0 auto;
}
.jieguo-pay__channel-toggle {
  display: flex;
  width: 100%;
  max-width: 280px;
  padding: 4px;
  border-radius: 12px;
  border: 1px solid rgba(196, 165, 116, 0.28);
  background: rgba(0, 0, 0, 0.28);
  box-shadow: inset 0 1px 0 rgba(255, 248, 235, 0.06);
  gap: 4px;
}
.jieguo-pay__channel-tab {
  flex: 1;
  margin: 0;
  padding: 0.5rem 0.65rem;
  border: none;
  border-radius: 9px;
  font-family: inherit;
  font-size: 0.88rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  color: var(--muted);
  background: transparent;
  cursor: pointer;
  transition: color 0.15s ease, background 0.15s ease, box-shadow 0.15s ease;
}
.jieguo-pay__channel-tab:hover {
  color: var(--fg-soft);
}
.jieguo-pay__channel-tab.is-active {
  color: #fdf8f0;
  background: linear-gradient(180deg, rgba(120, 100, 72, 0.55) 0%, rgba(48, 42, 34, 0.85) 100%);
  box-shadow:
    0 1px 0 rgba(255, 248, 220, 0.1) inset,
    0 2px 8px rgba(0, 0, 0, 0.35);
}
.jieguo-pay__channel-tab:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}
.jieguo-pay__qr-single .jieguo-pay__mock-card {
  width: 100%;
  max-width: 280px;
  margin: 0;
  flex: none;
}
.jieguo-pay__mock-card {
  flex: 1 1 240px;
  max-width: 280px;
  padding: 1rem 1.1rem 1.05rem;
  border-radius: var(--radius);
  text-align: center;
  border: 1px solid rgba(0, 0, 0, 0.35);
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.35);
}
.jieguo-pay__mock-card--wx {
  background: linear-gradient(180deg, rgba(7, 193, 96, 0.14) 0%, rgba(10, 9, 8, 0.96) 42%);
  border-color: rgba(7, 193, 96, 0.45);
}
.jieguo-pay__mock-card--alipay {
  background: linear-gradient(180deg, rgba(22, 119, 255, 0.12) 0%, rgba(10, 9, 8, 0.96) 42%);
  border-color: rgba(22, 119, 255, 0.42);
}
.jieguo-pay__mock-brand {
  font-size: 1.05rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  margin-bottom: 0.35rem;
  color: #f5efe6;
}
.jieguo-pay__mock-card--wx .jieguo-pay__mock-brand {
  color: #b8f0d0;
}
.jieguo-pay__mock-card--alipay .jieguo-pay__mock-brand {
  color: #c8dcff;
}
.jieguo-pay__mock-amount {
  font-size: 1.35rem;
  font-weight: 700;
  font-family: var(--font-serif);
  color: #faf6f0;
  margin-bottom: 0.65rem;
}
.jieguo-pay__mock-currency {
  font-size: 0.95rem;
  margin-right: 0.15rem;
  opacity: 0.9;
}
.jieguo-pay__mock-tag {
  display: inline-block;
  margin-left: 0.45rem;
  padding: 0.08rem 0.35rem;
  border-radius: 4px;
  font-size: 0.65rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  vertical-align: middle;
  background: rgba(0, 0, 0, 0.35);
  color: rgba(255, 248, 235, 0.85);
}
.jieguo-pay__mock-qr-wrap {
  display: inline-block;
  padding: 0.5rem;
  border-radius: 6px;
  background: #fff;
  line-height: 0;
  box-shadow: inset 0 0 0 1px rgba(0, 0, 0, 0.06);
}
.jieguo-pay__mock-qr-img {
  display: block;
  width: 220px;
  max-width: 100%;
  height: auto;
  aspect-ratio: 1;
}
.jieguo-pay__mock-tip {
  margin: 0.55rem 0 0;
  font-size: 0.78rem;
  color: var(--muted);
  letter-spacing: 0.04em;
}
.jieguo-pay__mock-fallback {
  margin-top: 1.1rem;
  padding: 0.65rem 0.75rem;
  border-radius: var(--radius-sm);
  border: 1px dashed rgba(196, 165, 116, 0.22);
  background: rgba(0, 0, 0, 0.18);
}
.jieguo-pay__mock-fallback-sum {
  cursor: pointer;
  font-size: 0.82rem;
  color: var(--muted);
}
.jieguo-pay__mock-fallback-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
  margin-top: 0.65rem;
}
.jieguo-pay__mock-mini-form {
  margin: 0;
}
.jieguo-pay__mock-mini-btn {
  font-size: 0.82rem;
  padding: 0.4rem 0.75rem;
}
.jieguo-pay__mock-mini-btn--wx {
  border-color: rgba(7, 193, 96, 0.45);
  color: #b8f0d0;
}
.jieguo-pay__mock-mini-btn--alipay {
  border-color: rgba(22, 119, 255, 0.45);
  color: #c8dcff;
}

/* 传统画框 · 结果页（画框随内容列，避免全宽 main 与窄报告错位） */
main.wrap.traditional-frame.jieguo-reading {
  position: relative;
  padding-bottom: 2.5rem;
  border-left: none;
  border-right: none;
  background-image: none;
}

main.wrap.traditional-frame.jieguo-reading::before,
main.wrap.traditional-frame.jieguo-reading::after {
  display: none;
}

.jieguo-reading > .result-block {
  position: relative;
  background-image: linear-gradient(
      90deg,
      rgba(196, 165, 116, 0.04) 0%,
      transparent 12%,
      transparent 88%,
      rgba(196, 165, 116, 0.04) 100%
    );
}

.jieguo-page .site-header {
  border-bottom-color: rgba(196, 165, 116, 0.22);
}
.jieguo-page .site-footer {
  border-top: 2px solid rgba(196, 165, 116, 0.12);
  background-image: repeating-linear-gradient(
    90deg,
    transparent,
    transparent 10px,
    rgba(196, 165, 116, 0.035) 10px,
    rgba(196, 165, 116, 0.035) 11px
  );
}

.jieguo-card__subtitle {
  font-size: 0.72rem;
  font-weight: 500;
  letter-spacing: 0.12em;
  color: var(--muted);
  margin-left: 0.5rem;
}
.jieguo-seal--locked {
  border-color: rgba(196, 165, 116, 0.45);
  color: var(--gold);
  transform: rotate(-2deg);
}

.jieguo-card--locked {
  position: relative;
  overflow: hidden;
}

.jieguo-pillar-cell--locked {
  position: relative;
  min-height: 6.5rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  border-style: dashed;
  border-color: rgba(196, 165, 116, 0.22);
  background: rgba(0, 0, 0, 0.25);
}
.jieguo-pillar-cell__mask {
  width: 70%;
  height: 2.5rem;
  margin-top: 0.35rem;
  border-radius: 6px;
  background: repeating-linear-gradient(
    -12deg,
    rgba(255, 248, 235, 0.05),
    rgba(255, 248, 235, 0.05) 3px,
    transparent 3px,
    transparent 10px
  );
  filter: blur(0.3px);
}
.jieguo-lock-label {
  margin-top: 0.35rem;
  font-size: 0.72rem;
  letter-spacing: 0.22em;
  color: var(--muted2);
}
.jieguo-lock-label--tile {
  position: absolute;
  right: 0.65rem;
  bottom: 0.55rem;
  margin: 0;
}

.jieguo-mosaic {
  min-height: 4.25rem;
  border-radius: var(--radius-sm);
  border: 1px dashed rgba(196, 165, 116, 0.18);
  background:
    repeating-linear-gradient(
      -8deg,
      rgba(255, 248, 235, 0.035),
      rgba(255, 248, 235, 0.035) 2px,
      transparent 2px,
      transparent 9px
    ),
    linear-gradient(180deg, rgba(0, 0, 0, 0.28), rgba(0, 0, 0, 0.5));
}
.jieguo-mosaic--short {
  min-height: 2.25rem;
}

.jieguo-locked-veil {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 38%;
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
  background: linear-gradient(180deg, transparent 0%, rgba(8, 7, 6, 0.55) 35%, rgba(8, 7, 6, 0.88) 100%);
  backdrop-filter: blur(1.5px);
  z-index: 2;
}
.jieguo-locked-veil--soft {
  height: 28%;
  background: linear-gradient(180deg, transparent 0%, rgba(8, 7, 6, 0.35) 40%, rgba(8, 7, 6, 0.72) 100%);
}
.jieguo-locked-veil__stamp {
  text-align: center;
  font-family: var(--font-serif);
  font-size: 0.95rem;
  font-weight: 800;
  letter-spacing: 0.28em;
  line-height: 1.65;
  color: rgba(232, 210, 170, 0.92);
  padding: 0.65rem 1rem;
  border: 2px solid rgba(196, 90, 72, 0.45);
  border-radius: 4px;
  background: rgba(32, 18, 14, 0.75);
  box-shadow: 0 8px 28px rgba(0, 0, 0, 0.45), inset 0 0 0 1px rgba(0, 0, 0, 0.35);
  transform: rotate(-3deg);
}

.jieguo-teaser--below {
  position: relative;
  z-index: 3;
  margin-top: 1.25rem;
}

.jieguo-cal-row--locked {
  opacity: 0.72;
  border-style: dashed;
}

.jieguo-wx-bars--ghost {
  opacity: 0.55;
}

.jieguo-name-row--locked {
  border-style: dashed;
  opacity: 0.68;
}
.jieguo-name-row__ghost {
  letter-spacing: 0.2em;
  color: var(--muted);
  font-size: 1rem;
}

.jieguo-horo-tile--locked {
  position: relative;
  min-height: 7rem;
}

.jieguo-overview-wrap {
  position: relative;
  z-index: 1;
}

/* —— 管理后台 —— */
body.admin-body {
  background: var(--bg-deep);
}

.admin-wrap {
  max-width: 960px;
}

.admin-title {
  font-size: 1.35rem;
  margin: 0 0 1rem;
}

.admin-nav {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.65rem 1rem;
  padding: 0.75rem 1rem;
  border-bottom: 1px solid var(--border);
  background: rgba(10, 14, 28, 0.85);
}

.admin-nav a {
  font-size: 0.92rem;
}

.admin-nav .inline-logout {
  margin: 0;
  margin-left: auto;
}

.admin-links {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.admin-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.9rem;
  margin-top: 1rem;
}

.admin-table th,
.admin-table td {
  border: 1px solid var(--border);
  padding: 0.45rem 0.5rem;
  text-align: left;
  vertical-align: top;
}

.admin-table thead th {
  background: rgba(255, 255, 255, 0.04);
}

.cell-ellipsis {
  max-width: 280px;
  word-break: break-word;
}

.cell-actions {
  white-space: nowrap;
}

.cell-actions .btn {
  margin-right: 0.35rem;
}

.inline-form {
  display: inline;
}

.inline-form button {
  vertical-align: middle;
}

.admin-wrap--wide {
  max-width: 1200px;
}

.admin-filters {
  margin-top: 0.5rem;
  padding: 1rem 1.1rem;
  border-radius: var(--radius);
  border: 1px solid var(--border);
  background: rgba(255, 255, 255, 0.03);
}

.admin-filters__row {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  gap: 0.75rem 1rem;
  margin-bottom: 0.65rem;
}

.admin-filters__row:last-child {
  margin-bottom: 0;
}

.admin-filters__field {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  font-size: 0.82rem;
  color: var(--muted);
}

.admin-filters__field--grow {
  flex: 1 1 220px;
  min-width: 180px;
}

.admin-filters__field input,
.admin-filters__field select {
  min-width: 0;
  font-size: 0.9rem;
}

.admin-filters__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-left: auto;
}

.admin-list-meta {
  margin: 0.85rem 0 0.35rem;
}

.admin-table-scroll {
  overflow-x: auto;
  margin-top: 0.35rem;
}

.admin-table--orders {
  min-width: 720px;
}

.admin-pagination {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.65rem 1rem;
  margin-top: 1rem;
}

.admin-badge {
  display: inline-block;
  padding: 0.12rem 0.45rem;
  border-radius: 4px;
  font-size: 0.76rem;
  font-weight: 600;
  letter-spacing: 0.04em;
}

.admin-badge--ok {
  background: rgba(72, 120, 88, 0.35);
  color: #c8e8d4;
}

.admin-badge--wait {
  background: rgba(120, 90, 48, 0.35);
  color: #e8d4b8;
}

.cell-mono {
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
  font-size: 0.78rem;
}

.admin-detail-card {
  margin-top: 1.25rem;
  padding: 1rem 1.1rem 1.1rem;
  border-radius: var(--radius);
  border: 1px solid var(--border);
  background: rgba(255, 255, 255, 0.03);
}

.admin-detail-card__title {
  margin: 0 0 0.75rem;
  font-size: 1.02rem;
  font-family: var(--font-serif);
}

.admin-dl {
  display: grid;
  grid-template-columns: minmax(7rem, 10rem) 1fr;
  gap: 0.35rem 0.75rem;
  margin: 0;
  font-size: 0.88rem;
}

.admin-dl dt {
  margin: 0;
  color: var(--muted);
}

.admin-dl dd {
  margin: 0;
  word-break: break-word;
}

.admin-code {
  margin: 0;
  padding: 0.75rem 0.85rem;
  max-height: min(70vh, 520px);
  overflow: auto;
  font-size: 0.78rem;
  line-height: 1.45;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
  border-radius: var(--radius-sm);
  border: 1px solid var(--border);
  background: rgba(0, 0, 0, 0.35);
  white-space: pre-wrap;
  word-break: break-word;
}

.admin-help-card {
  margin-bottom: 1.25rem;
  padding: 1rem 1.1rem;
  border-radius: var(--radius);
  border: 1px solid var(--border);
  background: rgba(255, 255, 255, 0.04);
}

.admin-help-card--warn {
  border-color: rgba(196, 165, 116, 0.35);
  background: rgba(196, 165, 116, 0.06);
}

.admin-help-card__label {
  margin: 0 0 0.25rem;
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--muted);
}

.admin-help-card__title {
  margin: 0 0 0.65rem;
  font-size: 1.05rem;
  font-family: var(--font-serif);
}

.admin-dl--stack {
  grid-template-columns: 1fr;
  gap: 0.2rem 0;
}

.admin-dl--stack dt {
  margin-top: 0.55rem;
  font-weight: 600;
  color: var(--fg-soft);
}

.admin-dl--stack dt:first-of-type {
  margin-top: 0;
}

.admin-dl--stack dd {
  margin-bottom: 0.15rem;
}

.admin-code-inline {
  padding: 0.12rem 0.35rem;
  border-radius: 4px;
  font-size: 0.86em;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
  background: rgba(0, 0, 0, 0.35);
  border: 1px solid var(--border);
}

.admin-table--seo-defaults .cell-wrap {
  max-width: 320px;
  font-size: 0.82rem;
  line-height: 1.45;
  word-break: break-word;
}

.admin-table--fallbacks .admin-code--in-cell {
  margin: 0;
  max-height: min(38vh, 320px);
  padding: 0.65rem 0.75rem;
  font-size: 0.78rem;
  line-height: 1.5;
  white-space: pre-wrap;
  word-break: break-word;
  overflow: auto;
}

.admin-playbook {
  margin: 0;
  padding-left: 1.15rem;
  font-size: 0.88rem;
  line-height: 1.65;
  color: var(--fg-soft);
}

.admin-playbook li {
  margin-bottom: 0.55rem;
}

.admin-playbook code {
  font-size: 0.86em;
}

.checkbox-row {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.checkbox-row input {
  width: auto;
}

button.btn-link {
  background: none;
  border: none;
  color: var(--accent);
  cursor: pointer;
  padding: 0;
  font: inherit;
  text-decoration: underline;
}

.admin-detail-card__head-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.65rem;
  margin-bottom: 0.75rem;
}

.admin-detail-card__head-row .admin-detail-card__title {
  margin: 0;
}

.admin-subtitle {
  margin: 1rem 0 0.45rem;
  font-size: 0.92rem;
  font-family: var(--font-serif);
  color: var(--fg-soft);
}

.admin-rule-list {
  margin: 0;
  padding-left: 1.15rem;
  font-size: 0.86rem;
  line-height: 1.65;
  color: var(--fg-soft);
}

.admin-rule-list li {
  margin-bottom: 0.4rem;
}

.admin-table--compact th,
.admin-table--compact td {
  padding: 0.35rem 0.55rem;
  font-size: 0.84rem;
}

.admin-bazi-grid-3 {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 0.85rem 1rem;
  margin-top: 0.5rem;
}

.admin-count-list {
  margin: 0;
  padding: 0;
  list-style: none;
  font-size: 0.84rem;
}

.admin-count-list li {
  display: flex;
  justify-content: space-between;
  gap: 0.5rem;
  padding: 0.2rem 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}

.admin-count-list__n {
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
  color: var(--gold);
}

.admin-dyun-list {
  margin: 0.35rem 0 0;
  padding-left: 1.1rem;
  font-size: 0.84rem;
  line-height: 1.55;
  color: var(--fg-soft);
}

.admin-flash-ok {
  margin: 0 0 0.75rem;
  padding: 0.5rem 0.75rem;
  font-size: 0.86rem;
  color: #b8e6c8;
  border: 1px solid rgba(80, 160, 100, 0.35);
  border-radius: var(--radius-sm);
  background: rgba(40, 80, 50, 0.25);
}

.admin-wx-summary {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-top: 0.5rem;
}

.admin-wx-chip {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.25rem 0.55rem;
  font-size: 0.82rem;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: rgba(255, 255, 255, 0.04);
}

.admin-wx-chip__n {
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
  color: var(--gold);
}

.admin-bazi-summary-excerpt {
  margin: 0.5rem 0 0;
  padding: 0.65rem 0.75rem;
  font-size: 0.84rem;
  line-height: 1.6;
  color: var(--muted2);
  border-left: 2px solid rgba(196, 165, 116, 0.35);
  background: rgba(0, 0, 0, 0.2);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
}

.jieguo-pay__provider-tag {
  font-size: 0.78em;
  font-weight: 500;
  opacity: 0.85;
  margin-left: 0.2em;
}

.payment-xorpay {
  padding-bottom: 2.5rem;
}
.payment-xorpay__qr-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.75rem;
  margin: 1.5rem 0;
}
.payment-xorpay__qr {
  border-radius: var(--radius);
  background: #fff;
  padding: 0.5rem;
}
.payment-xorpay__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  justify-content: center;
}
