/* ============================================================
   子平洞见 — Cosmos Design System
   深空宇宙 × 量子光芒 × 东方哲学
   ============================================================ */
:root {
  /* 宇宙色板 */
  --void: #05060f;
  --void-soft: #0a0e1a;
  --nebula: #0d1129;
  --nebula-light: #131a3a;
  --cosmos: #1a1f42;

  /* 光芒色 */
  --star-gold: #f0c850;
  --star-gold-dim: #c9a030;
  --star-white: #e8eaff;
  --aurora-cyan: #4de8d8;
  --aurora-blue: #3a8fff;
  --aurora-purple: #8a6bff;
  --nova-red: #ff5a6a;

  /* 五行 — 发光版 */
  --wood: #2ee86a;
  --wood-glow: rgba(46,232,106,0.25);
  --fire: #ff4d5a;
  --fire-glow: rgba(255,77,90,0.25);
  --earth: #ffb830;
  --earth-glow: rgba(255,184,48,0.25);
  --metal: #8ab4ff;
  --metal-glow: rgba(138,180,255,0.25);
  --water: #3a8fff;
  --water-glow: rgba(58,143,255,0.25);

  /* 文字 */
  --tx-bright: #f0f2ff;
  --tx-mid: #9aa0c0;
  --tx-dim: #556080;

  /* 表面 */
  --glass: rgba(15,20,45,0.75);
  --glass-border: rgba(120,140,255,0.12);
  --glass-hover: rgba(25,35,70,0.8);

  /* 圆角 */
  --r-sm: 8px;
  --r-md: 14px;
  --r-lg: 20px;
  --r-xl: 28px;
  --r-full: 999px;

  /* 兼容旧代码引用 */
  --bg-page: var(--void);
  --bg-card: var(--glass);
  --border: var(--glass-border);
  --error: var(--nova-red);
}

/* ── Reset ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html,body{height:100%;overflow:hidden;}
body{
  font-family:"Noto Sans SC","PingFang SC",sans-serif;
  background:var(--void);
  color:var(--tx-bright);
  -webkit-font-smoothing:antialiased;
}

/* ── Star Canvas (背景星空) ── */
#star-canvas{
  position:fixed;inset:0;z-index:0;pointer-events:none;
}

/* ── App Shell ── */
.app-shell{
  max-width:480px;margin:0 auto;
  height:100vh;height:100dvh;
  display:flex;flex-direction:column;
  position:relative;z-index:1;overflow:hidden;
}

/* ── Screen System ── */
.screen{
  display:none;flex-direction:column;flex:1;
  overflow-y:auto;overflow-x:hidden;
  padding-bottom:80px;
  scrollbar-width:thin;
  scrollbar-color:rgba(77,232,216,0.45) rgba(120,140,255,0.12);
}
.screen::-webkit-scrollbar{width:5px;}
.screen::-webkit-scrollbar-track{background:rgba(120,140,255,0.1);}
.screen::-webkit-scrollbar-thumb{background:rgba(77,232,216,0.45);border-radius:999px;}
.screen.active{display:flex;}

/* ── Glass Card (通用毛玻璃卡片) ── */
.glass-card{
  background:var(--glass);
  border:1px solid var(--glass-border);
  border-radius:var(--r-lg);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
}

/* ── Bottom Tab Bar ── */
.tabbar{
  position:fixed;bottom:0;left:50%;transform:translateX(-50%);
  width:100%;max-width:480px;z-index:100;
  display:flex;
  background:rgba(5,6,15,0.92);
  border-top:1px solid rgba(120,140,255,0.08);
  backdrop-filter:blur(30px);
  -webkit-backdrop-filter:blur(30px);
  padding-bottom:env(safe-area-inset-bottom,0);
}
.tab{
  flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;
  padding:10px 4px 8px;border:none;background:transparent;
  color:var(--tx-dim);cursor:pointer;transition:all 0.3s;
  position:relative;
}
.tab.active{color:var(--aurora-cyan);}
.tab.active::before{
  content:'';position:absolute;top:-1px;left:20%;right:20%;height:2px;
  background:linear-gradient(90deg,transparent,var(--aurora-cyan),transparent);
  border-radius:2px;
}
.tab-icon{font-size:20px;line-height:1;transition:transform 0.3s;}
.tab.active .tab-icon{transform:scale(1.15);}
.tab-label{font-size:10px;letter-spacing:1px;font-weight:500;}

/* ============================================================
   排盘输入页
   ============================================================ */
#screen-pai{background:transparent;}

.cosmic-header{
  padding:52px 24px 20px;
  display:flex;align-items:center;justify-content:space-between;
}
.logo-group{display:flex;align-items:center;gap:14px;}
.logo-orb{
  width:44px;height:44px;border-radius:50%;
  background:radial-gradient(circle at 35% 35%,var(--star-gold),#8a6020);
  box-shadow:0 0 20px rgba(240,200,80,0.4),0 0 60px rgba(240,200,80,0.15);
  display:flex;align-items:center;justify-content:center;
  font-size:22px;animation:orb-pulse 4s ease-in-out infinite;
}
@keyframes orb-pulse{
  0%,100%{box-shadow:0 0 20px rgba(240,200,80,0.4),0 0 60px rgba(240,200,80,0.15);}
  50%{box-shadow:0 0 30px rgba(240,200,80,0.6),0 0 80px rgba(240,200,80,0.25);}
}
.logo-text .logo-title{
  font-family:"Noto Serif SC",serif;font-size:22px;font-weight:900;
  letter-spacing:3px;
  background:linear-gradient(135deg,#f0c850,#fff,#f0c850);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
}
.logo-text .logo-sub{
  font-size:11px;color:var(--tx-dim);letter-spacing:2px;margin-top:2px;
}

.charts-btn{
  display:flex;align-items:center;gap:6px;
  padding:8px 16px;border-radius:var(--r-full);
  background:rgba(77,232,216,0.08);border:1px solid rgba(77,232,216,0.2);
  color:var(--aurora-cyan);font-size:12px;cursor:pointer;
  transition:all 0.3s;
}
.charts-btn:active{background:rgba(77,232,216,0.15);}

/* 输入表单 */
.form-container{
  margin:8px 16px 0;padding:24px 20px 28px;
  position:relative;overflow:hidden;
}
.form-container::before{
  content:'';position:absolute;top:-50%;left:-50%;width:200%;height:200%;
  background:radial-gradient(ellipse at 30% 20%,rgba(58,143,255,0.06) 0%,transparent 60%),
             radial-gradient(ellipse at 70% 80%,rgba(138,107,255,0.04) 0%,transparent 60%);
  pointer-events:none;
}

.form-row{display:flex;gap:12px;position:relative;z-index:1;}
.form-field{
  display:flex;flex-direction:column;gap:6px;flex:1;
  margin-bottom:16px;position:relative;z-index:1;
}
.form-field.flex-2{flex:2;}

.field-label{
  font-size:11px;color:var(--tx-dim);letter-spacing:1.5px;
  text-transform:uppercase;font-weight:500;
}
.field-label .optional{font-size:10px;color:var(--tx-dim);opacity:0.6;}

.field-input,.field-select{
  border:1px solid rgba(120,140,255,0.15);
  border-radius:var(--r-md);padding:12px 14px;
  font-size:15px;font-family:inherit;
  background:rgba(10,14,26,0.6);color:var(--tx-bright);
  outline:none;transition:all 0.3s;width:100%;
  -webkit-appearance:none;appearance:none;
}
.field-input:focus,.field-select:focus{
  border-color:var(--aurora-cyan);
  box-shadow:0 0 0 3px rgba(77,232,216,0.1),0 0 20px rgba(77,232,216,0.05);
}
.field-select{
  background:rgba(10,14,26,0.6) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%234de8d8' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E") no-repeat right 14px center;
  cursor:pointer;padding-right:36px;
}
.field-select option{background:#0d1129;color:#f0f2ff;}

/* Segment Control */
.seg{
  display:flex;border-radius:var(--r-full);
  border:1px solid rgba(120,140,255,0.15);
  overflow:hidden;background:rgba(10,14,26,0.4);height:42px;
}
.seg-btn{
  flex:1;border:none;background:transparent;
  font-size:14px;color:var(--tx-dim);cursor:pointer;
  font-family:inherit;transition:all 0.25s;font-weight:500;
  position:relative;
}
.seg-btn.active{
  background:linear-gradient(135deg,rgba(77,232,216,0.2),rgba(58,143,255,0.2));
  color:var(--aurora-cyan);
  box-shadow:inset 0 0 20px rgba(77,232,216,0.08);
}

/* Toggle */
.switch-field{flex-direction:row;align-items:center;justify-content:space-between;}
.toggle{position:relative;display:inline-block;width:48px;height:26px;}
.toggle input{opacity:0;width:0;height:0;}
.toggle-track{
  position:absolute;inset:0;
  background:rgba(120,140,255,0.15);border-radius:var(--r-full);
  transition:background 0.3s;cursor:pointer;
}
.toggle-track::after{
  content:'';position:absolute;left:3px;top:3px;
  width:20px;height:20px;border-radius:50%;
  background:var(--tx-dim);transition:all 0.3s;
}
.toggle input:checked + .toggle-track{background:rgba(77,232,216,0.3);}
.toggle input:checked + .toggle-track::after{
  transform:translateX(22px);
  background:var(--aurora-cyan);
  box-shadow:0 0 10px rgba(77,232,216,0.5);
}

.error-msg{color:var(--nova-red);font-size:13px;min-height:18px;}

/* CTA Button */
.cta-btn{
  width:100%;border:none;height:54px;
  border-radius:var(--r-full);
  font-size:17px;font-weight:700;
  font-family:"Noto Serif SC",serif;
  letter-spacing:3px;cursor:pointer;
  position:relative;overflow:hidden;
  color:#fff;
  background:linear-gradient(135deg,var(--aurora-cyan),var(--aurora-blue),var(--aurora-purple));
  box-shadow:0 4px 24px rgba(77,232,216,0.3),0 0 60px rgba(77,232,216,0.1);
  transition:all 0.3s;
  display:flex;align-items:center;justify-content:center;gap:10px;
  margin-top:8px;
}
.cta-btn::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,transparent 30%,rgba(255,255,255,0.15) 50%,transparent 70%);
  transform:translateX(-100%);
  transition:transform 0.6s;
}
.cta-btn:hover::before{transform:translateX(100%);}
.cta-btn:active{transform:scale(0.98);box-shadow:0 2px 16px rgba(77,232,216,0.2);}
.cta-icon{font-size:16px;animation:twinkle 2s ease-in-out infinite;}
@keyframes twinkle{0%,100%{opacity:1;}50%{opacity:0.5;}}

/* ============================================================
   结果页 / 命盘子页签
   ============================================================ */
#screen-result{
  background:transparent;
  overflow:hidden;
  padding-bottom:0;
}

/* 命盘导航 */
.mingpan-nav-shell{
  flex-shrink:0;
  position:sticky;top:0;z-index:10;
  padding:10px 12px 8px;
  background:linear-gradient(180deg,rgba(4,7,20,0.96),rgba(4,7,20,0.82));
  backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  border-bottom:1px solid rgba(120,140,255,0.08);
}

.mingpan-tabbar{
  --mingpan-index:0;
  position:relative;
  display:flex;align-items:stretch;
  padding:4px;
  border-radius:18px;
  background:linear-gradient(180deg,rgba(18,25,56,0.96),rgba(9,14,36,0.92));
  border:1px solid rgba(120,140,255,0.14);
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.04),0 10px 32px rgba(0,0,0,0.24);
}
.mingpan-tabbar::after{
  content:'';
  position:absolute;
  left:4px;top:4px;bottom:4px;
  width:calc((100% - 8px) / 3);
  border-radius:14px;
  background:
    radial-gradient(circle at 20% 20%,rgba(255,255,255,0.18),transparent 45%),
    linear-gradient(180deg,rgba(78,227,215,0.24),rgba(92,138,255,0.12));
  border:1px solid rgba(110,210,230,0.18);
  box-shadow:0 10px 26px rgba(48,120,255,0.18);
  transform:translateX(calc(var(--mingpan-index) * 100%));
  transition:transform 0.34s cubic-bezier(.22,1,.36,1);
}

.mingpan-tab{
  position:relative;z-index:1;
  flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:2px;min-height:52px;padding:8px 4px 7px;
  background:none;border:none;cursor:pointer;
  color:var(--tx-dim);
  transition:color 0.24s ease, transform 0.24s ease;
}
.mingpan-tab.active{
  color:#eef7ff;
}
.mingpan-tab:active{transform:scale(0.985);}

.mingpan-tab-kicker{
  font-size:9px;letter-spacing:1.6px;text-transform:uppercase;
  opacity:0.6;
}
.mingpan-tab-text{
  font-family:"Noto Serif SC",serif;
  font-size:14px;font-weight:700;letter-spacing:0.8px;
}

.mingpan-swipe-hint{
  display:flex;align-items:center;justify-content:center;gap:8px;
  padding-top:8px;
  font-size:10px;letter-spacing:1.6px;color:rgba(145,162,210,0.72);
}
.mingpan-swipe-line{
  width:28px;height:1px;
  background:linear-gradient(90deg,transparent,rgba(120,140,255,0.35),transparent);
}

/* 滑页容器 */
.mingpan-panels{
  position:relative;
  flex:1;
  overflow:hidden;
}

.mingpan-panel{
  position:absolute;inset:0;
  display:flex;flex-direction:column;
  overflow-y:auto;overflow-x:hidden;
  padding-bottom:80px;
  scrollbar-width:thin;
  scrollbar-color:rgba(77,232,216,0.45) rgba(120,140,255,0.12);
  opacity:0;
  pointer-events:none;
  transform:translateX(26px) scale(0.985);
  transition:
    transform 0.42s cubic-bezier(.22,1,.36,1),
    opacity 0.3s ease,
    filter 0.3s ease;
  filter:blur(2px);
}
.mingpan-panel::-webkit-scrollbar{width:5px;}
.mingpan-panel::-webkit-scrollbar-track{background:rgba(120,140,255,0.1);}
.mingpan-panel::-webkit-scrollbar-thumb{background:rgba(77,232,216,0.45);border-radius:999px;}
.mingpan-panel.active{
  opacity:1;
  pointer-events:auto;
  transform:translateX(0) scale(1);
  filter:none;
  z-index:2;
}
.mingpan-panel.is-enter-left{transform:translateX(-26px) scale(0.985);}
.mingpan-panel.is-enter-right{transform:translateX(26px) scale(0.985);}
.mingpan-panel.is-exit-left{
  opacity:0;
  transform:translateX(-34px) scale(0.98);
  filter:blur(3px);
}
.mingpan-panel.is-exit-right{
  opacity:0;
  transform:translateX(34px) scale(0.98);
  filter:blur(3px);
}

/* Hero Section */
.result-hero{
  padding:44px 24px 28px;text-align:center;
  position:relative;overflow:hidden;
}
.result-hero::before{
  content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);
  width:300px;height:300px;
  background:radial-gradient(circle,rgba(240,200,80,0.1) 0%,transparent 70%);
  pointer-events:none;
}
.hero-person{
  font-size:13px;color:var(--tx-dim);letter-spacing:2px;
  position:relative;z-index:1;
}
.hero-master{
  font-family:"Noto Serif SC",serif;font-size:42px;font-weight:900;
  letter-spacing:6px;margin:8px 0 4px;position:relative;z-index:1;
  background:linear-gradient(180deg,var(--star-gold),#fff8e0,var(--star-gold));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
  text-shadow:none;
  filter:drop-shadow(0 0 20px rgba(240,200,80,0.3));
}
.hero-meta{font-size:12px;color:var(--tx-dim);letter-spacing:1px;position:relative;z-index:1;}
.hero-tst{font-size:11px;color:var(--aurora-cyan);opacity:0.7;margin-top:4px;position:relative;z-index:1;}

/* ── 四柱星阵 ── */
.bazi-constellation, .bazi-panel{
  padding:0 12px;margin-bottom:16px;
}
.bazi-table{
  display:grid;
  grid-template-columns:24px repeat(4,1fr);
  border-radius:var(--r-lg);overflow:hidden;
  border:1px solid var(--glass-border);
  gap:1px;background:rgba(120,140,255,0.06);
}
.bt-label{
  background:rgba(15,20,45,0.9);
  display:flex;align-items:center;justify-content:center;
  font-size:9px;color:var(--tx-dim);text-align:center;
  line-height:1.3;padding:2px;
}
.bt-cell{
  background:rgba(10,15,35,0.85);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:4px 3px;min-height:28px;text-align:center;
  font-size:11px;color:var(--tx-mid);
  transition:background 0.3s;
}
.bt-cell.is-day-col{background:rgba(240,200,80,0.04);}
.bt-header{
  background:rgba(20,28,60,0.9);color:var(--tx-mid);
  font-size:11px;font-weight:600;letter-spacing:2px;min-height:28px;
}
.bt-header.is-day-col{
  background:linear-gradient(180deg,rgba(240,200,80,0.15),rgba(240,200,80,0.05));
  color:var(--star-gold);
}
.bt-stem,.bt-branch{min-height:52px;}
.bt-char{
  font-family:"Noto Serif SC",serif;font-size:30px;font-weight:900;line-height:1;
}
/* 日柱天干/地支特殊效果 */
.bt-stem.is-day-col .bt-char,
.bt-branch.is-day-col .bt-char{
  filter:drop-shadow(0 0 8px rgba(240,200,80,0.3));
}

/* 五行发光色 */
.el-wood{color:var(--wood);}
.el-fire{color:var(--fire);}
.el-earth{color:var(--earth);}
.el-metal{color:var(--metal);}
.el-water{color:var(--water);}
.el-wood-bg{background:rgba(46,232,106,0.06)!important;}
.el-fire-bg{background:rgba(255,77,90,0.06)!important;}
.el-earth-bg{background:rgba(255,184,48,0.06)!important;}
.el-metal-bg{background:rgba(138,180,255,0.06)!important;}
.el-water-bg{background:rgba(58,143,255,0.06)!important;}

.bt-stem.is-day-col.el-wood-bg{background:rgba(46,232,106,0.1)!important;}
.bt-stem.is-day-col.el-fire-bg{background:rgba(255,77,90,0.1)!important;}
.bt-stem.is-day-col.el-earth-bg{background:rgba(255,184,48,0.1)!important;}
.bt-stem.is-day-col.el-metal-bg{background:rgba(138,180,255,0.1)!important;}
.bt-stem.is-day-col.el-water-bg{background:rgba(58,143,255,0.1)!important;}
.bt-branch.is-day-col.el-wood-bg{background:rgba(46,232,106,0.1)!important;}
.bt-branch.is-day-col.el-fire-bg{background:rgba(255,77,90,0.1)!important;}
.bt-branch.is-day-col.el-earth-bg{background:rgba(255,184,48,0.1)!important;}
.bt-branch.is-day-col.el-metal-bg{background:rgba(138,180,255,0.1)!important;}
.bt-branch.is-day-col.el-water-bg{background:rgba(58,143,255,0.1)!important;}

.bt-shishen{min-height:26px;font-size:11px;}
.bt-hidden{min-height:30px;flex-direction:row;flex-wrap:wrap;gap:2px;padding:4px 3px;}
.bt-hidden-stem{font-family:"Noto Serif SC",serif;font-size:14px;font-weight:700;}
.bt-hidden-gods{min-height:24px;flex-direction:row;flex-wrap:wrap;gap:1px;padding:3px;}
.bt-hidden-god{font-size:9px;color:var(--tx-dim);}
.bt-xingyun,.bt-kongwang{min-height:24px;font-size:11px;}
.bt-nayin{min-height:22px;font-size:10px;color:var(--tx-dim);padding:3px 2px;line-height:1.3;}
.bt-shensha{min-height:26px;padding:4px 2px;display:flex;flex-wrap:wrap;gap:3px;align-items:flex-start;justify-content:center;align-content:center;}
.bt-sha-tag{
  display:inline-block;font-size:9px;line-height:1.3;
  padding:2px 5px;border-radius:4px;
  background:rgba(120,140,255,0.1);color:var(--tx-mid);white-space:nowrap;
}

/* ── 神煞展开面板（表格外部） ── */
.shensha-expand-panel{
  margin:0 12px 8px;border-radius:var(--r-md);overflow:hidden;
  border:1px solid var(--glass-border);
  background:rgba(10,15,35,0.7);
}
.shensha-expand-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 14px;cursor:pointer;user-select:none;
  transition:background 0.2s;
}
.shensha-expand-header:active{background:rgba(120,140,255,0.06);}
.shensha-expand-title{
  font-size:11px;color:var(--tx-dim);letter-spacing:2px;font-weight:600;
  display:flex;align-items:center;gap:8px;
}
.shensha-expand-arrow{
  font-size:12px;color:var(--tx-dim);transition:transform 0.3s;
  display:inline-block;
}
.shensha-expand-arrow.open{transform:rotate(180deg);}
.shensha-expand-summary{
  display:flex;gap:4px;flex-wrap:wrap;flex:1;justify-content:flex-end;
  max-width:60%;transition:opacity 0.3s;
}
.shensha-expand-summary .bt-sha-tag{font-size:10px;padding:2px 6px;}
.shensha-expand-body{
  max-height:0;overflow:hidden;transition:max-height 0.4s cubic-bezier(0.22,1,0.36,1);
}
.shensha-expand-body.open{max-height:500px;}
.shensha-detail-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1px;
  background:rgba(120,140,255,0.06);
  border-top:1px solid var(--glass-border);
}
.shensha-detail-col{
  background:rgba(10,15,35,0.85);padding:10px 8px;
  display:flex;flex-direction:column;align-items:center;gap:6px;
}
.shensha-detail-col.is-day{background:rgba(240,200,80,0.04);}
.shensha-col-title{font-size:10px;color:var(--tx-dim);letter-spacing:1px;font-weight:600;}
.shensha-col-title.is-day{color:var(--star-gold);}
.shensha-col-tags{display:flex;flex-direction:column;gap:4px;align-items:center;width:100%;}
.shensha-col-tags .sha-tag-item{
  font-size:10px;padding:3px 8px;border-radius:var(--r-full);
  background:rgba(120,140,255,0.06);border:1px solid rgba(120,140,255,0.1);
  color:var(--tx-mid);text-align:center;width:100%;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.shensha-col-tags .sha-tag-item.auspicious{
  border-color:rgba(77,232,216,0.25);color:var(--aurora-cyan);background:rgba(77,232,216,0.05);
}
.shensha-col-tags .sha-tag-item.inauspicious{
  border-color:rgba(255,90,106,0.25);color:var(--nova-red);background:rgba(255,90,106,0.05);
}
.shensha-col-empty{font-size:10px;color:var(--tx-dim);opacity:0.4;}

/* ── 五行能量环 ── */
.wuxing-panel{padding:8px 16px 12px;}
.panel-title{
  font-size:11px;color:var(--tx-dim);letter-spacing:4px;
  margin-bottom:10px;display:flex;align-items:center;gap:10px;
  text-transform:uppercase;font-weight:600;
}
.panel-title::after{content:'';flex:1;height:1px;background:linear-gradient(90deg,var(--glass-border),transparent);}

.wuxing-bars{display:flex;flex-direction:column;gap:8px;}
.wx-row{display:flex;align-items:center;gap:10px;}
.wx-label{font-size:14px;font-weight:700;width:18px;text-align:center;}
.wx-bar-bg{
  flex:1;height:6px;
  background:rgba(120,140,255,0.08);
  border-radius:4px;overflow:hidden;
}
.wx-bar{
  height:100%;border-radius:4px;
  transition:width 1.2s cubic-bezier(0.22,1,0.36,1);
  min-width:3px;position:relative;
}
.wx-bar.el-wood-bg{background:linear-gradient(90deg,var(--wood),rgba(46,232,106,0.5));box-shadow:0 0 10px var(--wood-glow);}
.wx-bar.el-fire-bg{background:linear-gradient(90deg,var(--fire),rgba(255,77,90,0.5));box-shadow:0 0 10px var(--fire-glow);}
.wx-bar.el-earth-bg{background:linear-gradient(90deg,var(--earth),rgba(255,184,48,0.5));box-shadow:0 0 10px var(--earth-glow);}
.wx-bar.el-metal-bg{background:linear-gradient(90deg,var(--metal),rgba(138,180,255,0.5));box-shadow:0 0 10px var(--metal-glow);}
.wx-bar.el-water-bg{background:linear-gradient(90deg,var(--water),rgba(58,143,255,0.5));box-shadow:0 0 10px var(--water-glow);}
.wx-bar.el-wood-bg{background:var(--wood);box-shadow:0 0 10px var(--wood-glow);}
.wx-bar.el-fire-bg{background:var(--fire);box-shadow:0 0 10px var(--fire-glow);}
.wx-bar.el-earth-bg{background:var(--earth);box-shadow:0 0 10px var(--earth-glow);}
.wx-bar.el-metal-bg{background:var(--metal);box-shadow:0 0 10px var(--metal-glow);}
.wx-bar.el-water-bg{background:var(--water);box-shadow:0 0 10px var(--water-glow);}
.wx-count{font-size:12px;color:var(--tx-dim);width:16px;text-align:right;font-weight:600;}

/* ── 神煞 ── */
.shensha-panel{padding:4px 16px 8px;}
.shensha-tags{display:flex;flex-wrap:wrap;gap:6px;}
.sha-tag{
  font-size:11px;padding:5px 12px;border-radius:var(--r-full);
  border:1px solid rgba(120,140,255,0.15);color:var(--tx-mid);
  background:rgba(15,20,45,0.6);letter-spacing:0.5px;
  transition:all 0.3s;
}
.sha-tag.auspicious{
  border-color:rgba(77,232,216,0.3);color:var(--aurora-cyan);
  background:rgba(77,232,216,0.06);
  box-shadow:0 0 12px rgba(77,232,216,0.08);
}
.sha-tag.inauspicious{
  border-color:rgba(255,90,106,0.3);color:var(--nova-red);
  background:rgba(255,90,106,0.06);
  box-shadow:0 0 12px rgba(255,90,106,0.08);
}

/* ── 原局关系 ── */
.guanxi-panel{padding:4px 16px 8px;}
.guanxi-body{display:flex;flex-direction:column;gap:6px;}
.guanxi-row{display:flex;flex-wrap:wrap;align-items:baseline;gap:5px;}
.guanxi-row-title{font-size:11px;color:var(--tx-dim);letter-spacing:0.5px;white-space:nowrap;flex-shrink:0;}
.guanxi-items{display:flex;flex-wrap:wrap;gap:5px;}
.guanxi-tag{
  font-size:11px;padding:3px 10px;border-radius:var(--r-full);
  background:rgba(15,20,45,0.6);border:1px solid var(--glass-border);
  color:var(--tx-mid);white-space:nowrap;
}
.guanxi-tag.ke{border-color:rgba(255,90,106,0.3);color:var(--nova-red);background:rgba(255,90,106,0.06);}
.guanxi-tag.he{border-color:rgba(77,232,216,0.3);color:var(--aurora-cyan);background:rgba(77,232,216,0.06);}
.guanxi-tag.chong{border-color:rgba(138,107,255,0.3);color:var(--aurora-purple);background:rgba(138,107,255,0.06);}
.guanxi-tag.xing{border-color:rgba(255,184,48,0.3);color:var(--earth);background:rgba(255,184,48,0.06);}
.guanxi-tag.hai{border-color:rgba(46,232,106,0.3);color:var(--wood);background:rgba(46,232,106,0.06);}
.guanxi-tag.gai{border-color:rgba(255,184,48,0.3);color:var(--earth);background:rgba(255,184,48,0.06);}

/* ── 大运/流年/流月/流日/流时 ── */
.yun-panel{padding:4px 16px 16px;display:flex;flex-direction:column;gap:0;}
.yun-row{padding:8px 0 4px;border-top:1px solid rgba(120,140,255,0.06);}
.yun-row:first-child{border-top:none;}
.yun-row-header{display:flex;align-items:center;gap:8px;margin-bottom:8px;}
.yun-row-title{
  font-size:11px;color:var(--tx-dim);letter-spacing:4px;flex-shrink:0;
  font-weight:600;text-transform:uppercase;
}
.yun-row-title::after{content:'';flex:1;height:1px;background:linear-gradient(90deg,var(--glass-border),transparent);}
.yun-sub-label{font-size:11px;color:var(--tx-dim);flex:1;}

.yun-scroll{
  display:flex;gap:8px;overflow-x:auto;padding-bottom:6px;
  scrollbar-width:none;
}
.yun-scroll::-webkit-scrollbar{display:none;}

.yun-item{
  flex-shrink:0;display:flex;flex-direction:column;align-items:center;gap:2px;
  background:rgba(15,20,45,0.6);border:1px solid rgba(120,140,255,0.1);
  border-radius:var(--r-sm);padding:7px 8px 6px;min-width:54px;
  text-align:center;cursor:pointer;user-select:none;
  transition:all 0.3s;
}
.yun-item:active{transform:scale(0.96);}
.yun-item.current{
  border-color:rgba(240,200,80,0.4);
  background:rgba(240,200,80,0.06);
  box-shadow:0 0 16px rgba(240,200,80,0.08);
}
.yun-item.active{
  border-color:rgba(77,232,216,0.4);
  background:rgba(77,232,216,0.06);
  box-shadow:0 0 16px rgba(77,232,216,0.08);
}
.yun-item.dayun-card{min-width:64px;padding:8px 10px 7px;}
.yun-gz-line{
  display:flex;align-items:baseline;gap:1px;
  font-family:"Noto Serif SC",serif;font-size:15px;font-weight:700;
}
.yun-gz-line.big{font-size:18px;}
.yun-god{font-size:9px;color:var(--tx-dim);font-family:"Noto Sans SC",sans-serif;font-weight:400;}
.yun-year-num{font-size:10px;color:var(--tx-dim);margin-top:2px;}
.yun-age-num{font-size:10px;color:var(--tx-dim);}
.yun-date-num{font-size:10px;color:var(--tx-dim);margin-top:1px;}

/* Result Footer */
.result-footer{
  padding:16px 16px 8px;display:flex;gap:10px;
}
.outline-btn{
  flex:1;border:1px solid var(--glass-border);
  background:var(--glass);color:var(--tx-mid);
  border-radius:var(--r-full);height:44px;font-size:13px;
  cursor:pointer;font-family:inherit;transition:all 0.3s;
  backdrop-filter:blur(10px);
}
.outline-btn:active{background:var(--glass-hover);border-color:var(--aurora-cyan);color:var(--aurora-cyan);}

.gen-report-btn{
  display:flex;align-items:center;gap:6px;
  padding:10px 20px;border-radius:var(--r-full);
  border:1px solid rgba(240,200,80,0.3);background:rgba(240,200,80,0.06);
  color:var(--star-gold);font-size:13px;font-weight:500;cursor:pointer;
  transition:all 0.3s;
}
.gen-report-btn:active{background:rgba(240,200,80,0.15);}

/* ============================================================
   报告页
   ============================================================ */
#screen-report{background:transparent;overflow:hidden;}
.report-header{
  display:flex;align-items:center;gap:14px;
  padding:48px 20px 16px;
  background:rgba(10,15,30,0.9);
  border-bottom:1px solid var(--glass-border);
}
.back-btn{
  border:none;background:rgba(120,140,255,0.1);color:var(--aurora-cyan);
  border-radius:50%;width:34px;height:34px;font-size:20px;
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  transition:all 0.3s;
}
.back-btn:active{background:rgba(120,140,255,0.2);}
.header-title{font-size:17px;font-weight:600;color:var(--tx-bright);letter-spacing:2px;}
.report-actions{margin-left:auto;display:flex;gap:8px;}
.report-copy-btn{
  padding:7px 14px;border-radius:var(--r-sm);
  border:1px solid var(--glass-border);background:transparent;
  color:var(--tx-mid);font-size:12px;cursor:pointer;transition:all 0.3s;
}
.report-copy-btn:active{background:var(--glass-hover);color:var(--aurora-cyan);}
.report-body{flex:1;position:relative;padding:0;}
.report-insight-bar{
  position:absolute;top:10px;left:10px;right:10px;z-index:11;
  padding:10px 12px;border-radius:14px;
  background:rgba(7,12,28,0.88);border:1px solid rgba(240,216,120,0.18);
  box-shadow:0 10px 24px rgba(0,0,0,0.22);backdrop-filter:blur(14px);
  color:var(--tx-bright);font-size:12px;line-height:1.6;
}
.report-insight-title{font-size:11px;letter-spacing:1.2px;color:#f0d878;margin-bottom:4px;}
.report-insight-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px;}
.report-insight-tag{
  display:inline-flex;align-items:center;padding:3px 8px;border-radius:999px;
  background:rgba(77,232,216,0.1);border:1px solid rgba(77,232,216,0.16);
  color:var(--aurora-cyan);font-size:11px;
}
.report-insight-points{margin-top:8px;padding-left:16px;color:var(--tx-mid);}
.report-insight-points li{margin:4px 0;}
.report-insight-warn{margin-top:6px;color:#ffb7a8;}
.report-loading{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:60px 20px;gap:16px;color:var(--tx-mid);font-size:14px;
  position:absolute;inset:0;z-index:10;background:var(--void);
}
.spinner{
  width:40px;height:40px;
  border:2px solid rgba(120,140,255,0.15);border-top-color:var(--aurora-cyan);
  border-radius:50%;animation:spin 0.8s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg);}}

/* ============================================================
   我的命盘列表页
   ============================================================ */
#screen-charts{background:transparent;}
.charts-body{flex:1;overflow-y:auto;padding:12px 16px 32px;}
.charts-empty{text-align:center;color:var(--tx-dim);padding:80px 24px;font-size:14px;line-height:1.8;}
.charts-empty-icon{font-size:48px;margin-bottom:12px;opacity:0.4;}
.charts-list{display:flex;flex-direction:column;gap:12px;}
.chart-card{
  border-radius:var(--r-lg);padding:16px 18px;
  display:flex;flex-direction:column;gap:8px;
  cursor:pointer;position:relative;
  transition:all 0.3s;
}
.chart-card:active{transform:scale(0.99);}
.chart-card-head{display:flex;justify-content:space-between;align-items:center;}
.chart-card-name{font-size:15px;font-weight:600;color:var(--tx-bright);}
.chart-card-gender{
  font-size:11px;color:var(--tx-dim);padding:3px 10px;
  border-radius:var(--r-full);background:rgba(120,140,255,0.08);
}
.chart-card-gz{
  display:flex;gap:10px;font-family:"Noto Serif SC",serif;
  font-size:16px;color:var(--star-gold);letter-spacing:1px;font-weight:700;
}
.chart-card-meta{display:flex;justify-content:space-between;font-size:11px;color:var(--tx-dim);}
.chart-card-del{
  position:absolute;top:12px;right:12px;width:28px;height:28px;border-radius:50%;
  border:none;background:rgba(255,90,106,0.08);color:var(--nova-red);
  font-size:14px;cursor:pointer;opacity:0.6;transition:opacity 0.3s;
}
.chart-card-del:active{opacity:1;background:rgba(255,90,106,0.2);}

/* ============================================================
   AI 问答页
   ============================================================ */
#screen-qa{background:transparent;padding-bottom:0;}
.qa-header{
  background:rgba(10,15,30,0.9);padding:48px 20px 14px;
  display:flex;align-items:center;gap:14px;
  border-bottom:1px solid var(--glass-border);
}

.chat-body{
  flex:1;overflow-y:auto;padding:16px;
  display:flex;flex-direction:column;gap:12px;
}
.chat-welcome{
  display:flex;flex-direction:column;align-items:center;gap:12px;
  padding:50px 24px;text-align:center;color:var(--tx-dim);
  font-size:14px;line-height:1.8;
}
.chat-welcome-icon{
  font-size:40px;
  filter:drop-shadow(0 0 20px rgba(77,232,216,0.3));
}

.qa-quick-questions{
  margin:0 16px 8px;
  padding:10px 12px;
  border-radius:12px;
  background:rgba(10,18,38,0.55);
  border:1px solid rgba(120,140,255,0.12);
}
.qa-quick-title{
  font-size:11px;
  color:var(--tx-dim);
  letter-spacing:1.4px;
  margin-bottom:8px;
}
.qa-quick-list{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.qa-quick-chip{
  border:1px solid rgba(77,232,216,0.2);
  background:rgba(77,232,216,0.08);
  color:var(--aurora-cyan);
  border-radius:999px;
  padding:5px 10px;
  font-size:12px;
  cursor:pointer;
}
.qa-quick-chip:active{transform:scale(0.97);}

.bubble{
  max-width:85%;padding:12px 16px;border-radius:16px;
  font-size:14px;line-height:1.7;
}
.bubble.user{
  align-self:flex-end;
  background:linear-gradient(135deg,rgba(77,232,216,0.2),rgba(58,143,255,0.2));
  border:1px solid rgba(77,232,216,0.2);color:var(--tx-bright);
  border-bottom-right-radius:4px;
}
.bubble.ai{
  align-self:flex-start;background:var(--glass);
  border:1px solid var(--glass-border);color:var(--tx-bright);
  border-bottom-left-radius:4px;
}
.bubble.ai.thinking{color:var(--tx-dim);font-style:italic;}
.chat-ai-meta{
  align-self:flex-start;max-width:85%;margin-top:-4px;padding:8px 10px 10px;
  border-radius:12px;background:rgba(10,18,38,0.55);border:1px solid rgba(120,140,255,0.08);
}
.chat-ai-meta-title{font-size:11px;color:#f0d878;letter-spacing:1px;margin-bottom:5px;}
.chat-ai-meta-tags{display:flex;flex-wrap:wrap;gap:6px;}
.chat-ai-meta-tag{
  display:inline-flex;align-items:center;padding:2px 8px;border-radius:999px;
  background:rgba(77,232,216,0.1);border:1px solid rgba(77,232,216,0.15);
  color:var(--aurora-cyan);font-size:11px;
}
.chat-ai-meta-points{margin-top:8px;padding-left:16px;color:var(--tx-mid);font-size:12px;line-height:1.6;}
.chat-ai-meta-points li{margin:4px 0;}
.chat-ai-meta-warn{margin-top:6px;font-size:11px;line-height:1.5;color:#ffb7a8;}

.chat-input-bar{
  display:flex;gap:10px;padding:12px 16px;
  border-top:1px solid var(--glass-border);
  background:rgba(5,6,15,0.95);
  backdrop-filter:blur(20px);
  padding-bottom:calc(12px + env(safe-area-inset-bottom,0));
}
.chat-textarea{
  flex:1;border:1px solid var(--glass-border);border-radius:var(--r-md);
  padding:10px 14px;font-size:14px;font-family:inherit;
  resize:none;background:rgba(15,20,45,0.6);color:var(--tx-bright);
  outline:none;line-height:1.5;transition:border-color 0.3s;
}
.chat-textarea:focus{border-color:var(--aurora-cyan);}
.send-btn{
  flex-shrink:0;width:46px;height:46px;border:none;
  background:linear-gradient(135deg,var(--aurora-cyan),var(--aurora-blue));
  color:#fff;border-radius:50%;font-size:16px;font-weight:700;
  cursor:pointer;align-self:flex-end;
  box-shadow:0 0 16px rgba(77,232,216,0.3);
  transition:all 0.3s;
}
.send-btn:active{transform:scale(0.92);}

.disclaimer{
  font-size:10px;color:var(--tx-dim);text-align:center;
  padding:6px 16px;background:rgba(5,6,15,0.9);margin:0;
  border-top:1px solid rgba(120,140,255,0.04);
}

/* ============================================================
   入场动画
   ============================================================ */
@keyframes fadeInUp{
  from{opacity:0;transform:translateY(20px);}
  to{opacity:1;transform:translateY(0);}
}
.animate-in{animation:fadeInUp 0.6s ease-out both;}
.animate-in:nth-child(1){animation-delay:0.05s;}
.animate-in:nth-child(2){animation-delay:0.1s;}
.animate-in:nth-child(3){animation-delay:0.15s;}
.animate-in:nth-child(4){animation-delay:0.2s;}
.animate-in:nth-child(5){animation-delay:0.25s;}

/* ============================================================
   流星效果
   ============================================================ */
.shooting-star{
  position:fixed;width:120px;height:1px;
  background:linear-gradient(90deg,rgba(255,255,255,0.6),transparent);
  opacity:0;z-index:0;pointer-events:none;
  animation:shoot 2s linear infinite;
}
@keyframes shoot{
  0%{transform:translateX(-100px) translateY(0);opacity:0;}
  5%{opacity:0.8;}
  30%{opacity:0;}
  100%{transform:translateX(500px) translateY(300px);opacity:0;}
}
.shooting-star:nth-child(2){animation-delay:4s;top:15%;left:60%;}
.shooting-star:nth-child(3){animation-delay:8s;top:40%;left:30%;}

/* ============================================================
   加载占位
   ============================================================ */
.loading-placeholder{
  text-align:center;padding:40px 16px;color:var(--tx-dim);font-size:14px;
  animation:pulse 1.4s ease-in-out infinite;
}
@keyframes pulse{0%,100%{opacity:0.5;}50%{opacity:1;}}

/* ============================================================
   紫微斗数 - 十二宫方形盘
   ============================================================ */
.ziwei-body{padding:8px 12px 12px;overflow-y:auto;}

.ziwei-info{
  background:rgba(255,255,255,0.04);border:1px solid rgba(120,140,255,0.15);
  border-radius:10px;padding:12px 14px;margin-bottom:10px;font-size:13px;
}
.ziwei-info .zw-row{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:4px;}
.ziwei-info .zw-item{color:var(--tx-dim);}
.ziwei-info .zw-item span{color:var(--tx-main);font-weight:600;}

/* 12宫外圈 4×4 - 中央2×2合并为命主信息 */
.ziwei-board{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  grid-template-rows:repeat(4,auto);
  gap:3px;
  margin:0 0 10px;
}
.zw-palace{
  background:rgba(255,255,255,0.03);
  border:1px solid rgba(120,140,255,0.12);
  border-radius:6px;padding:6px 5px;min-height:80px;
  display:flex;flex-direction:column;gap:2px;
  font-size:11px;color:var(--tx-dim);position:relative;
}
.zw-palace.is-soul{border-color:rgba(255,200,80,0.5);background:rgba(255,200,80,0.06);}
.zw-palace.is-life{border-color:rgba(120,200,255,0.5);background:rgba(120,200,255,0.06);}
.zw-palace-name{font-size:12px;font-weight:700;color:var(--tx-main);}
.zw-palace-stem{font-size:10px;color:var(--accent-2);opacity:0.8;}
.zw-palace-branch{font-size:10px;color:var(--accent-1);opacity:0.8;}
.zw-major-stars{color:#f4c542;font-size:11px;line-height:1.4;word-break:break-all;}
.zw-minor-stars{color:#8ab4f8;font-size:10px;line-height:1.4;word-break:break-all;}

/* 中央占位格 */
.zw-center{
  grid-column:2/4;grid-row:2/4;
  background:rgba(120,140,255,0.07);
  border:1px solid rgba(120,140,255,0.25);
  border-radius:8px;padding:10px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;
}
.zw-center-title{font-size:14px;font-weight:700;color:var(--accent-1);letter-spacing:2px;}
.zw-center-row{font-size:12px;color:var(--tx-dim);}
.zw-center-row span{color:var(--tx-main);font-weight:600;}

/* ============================================================
   奇门遁甲 - 九宫格盘
   ============================================================ */
.qimen-body{padding:8px 12px 12px;overflow-y:auto;}

.qimen-info{
  background:rgba(255,255,255,0.04);border:1px solid rgba(120,140,255,0.15);
  border-radius:10px;padding:12px 14px;margin-bottom:10px;font-size:13px;
}
.qimen-info .qm-row{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:4px;}
.qimen-info .qm-item{color:var(--tx-dim);}
.qimen-info .qm-item span{color:var(--tx-main);font-weight:600;}

/* 指符使格 */
.qimen-zfu{
  background:rgba(255,200,80,0.06);border:1px solid rgba(255,200,80,0.25);
  border-radius:8px;padding:8px 12px;margin-bottom:10px;font-size:12px;
  display:flex;gap:16px;flex-wrap:wrap;color:var(--tx-dim);
}
.qimen-zfu span{color:#f4c542;font-weight:600;}

.qimen-board{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  grid-template-rows:repeat(3,auto);
  gap:4px;
  margin:0 0 10px;
}
.qm-gong{
  background:rgba(255,255,255,0.03);
  border:1px solid rgba(120,140,255,0.12);
  border-radius:6px;padding:7px 6px;min-height:88px;
  display:flex;flex-direction:column;gap:2px;
  font-size:11px;color:var(--tx-dim);
}
.qm-gong.is-center{background:rgba(120,140,255,0.07);border-color:rgba(120,140,255,0.3);}
.qm-gong-name{font-size:12px;font-weight:700;color:var(--tx-main);}
.qm-gong-dir{font-size:10px;color:var(--accent-2);opacity:0.7;}
.qm-gong-di{font-size:11px;color:#8ab4f8;}   /* 地盘 */
.qm-gong-tian{font-size:11px;color:#f4c542;}  /* 天盘星 */
.qm-gong-ren{font-size:11px;color:#81e6d9;}   /* 人盘门 */
.qm-gong-shen{font-size:10px;color:#fc8181;}  /* 神 */
