/* ============================================================
   紫微斗数模块样式 (zw- 前缀) — 全新5层专业命盘
   ============================================================ */

/* ── 通用标题 ── */
.zw-section-title {
  font-family: 'Noto Serif SC', serif;
  font-size: 15px;
  font-weight: 600;
  color: #1f2937;
  margin-bottom: 14px;
  display: flex;
  align-items: center;
}

.zw-sub-title {
  font-family: 'Noto Serif SC', serif;
  font-size: 13px;
  font-weight: 600;
  color: #374151;
  margin-bottom: 10px;
  display: flex;
  align-items: center;
}

/* ── 命盘总览卡片 ── */
.zw-chart-card { overflow: visible; }
.zw-grid-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }

/* ── 命盘4×4网格 ── */
.zw-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-template-rows: repeat(4, auto);
  gap: 3px;
  margin-bottom: 10px;
  min-width: 520px;
}

.zw-cell {
  background: rgba(255, 255, 255, 0.55);
  border: 1px solid rgba(0, 0, 0, 0.06);
  border-radius: 6px;
  padding: 4px 5px;
  min-height: 90px;
  font-size: 10px;
  transition: all 0.2s ease;
  display: flex;
  flex-direction: column;
  gap: 1px;
  overflow: hidden;
}

.zw-cell:hover {
  background: rgba(108, 92, 231, 0.06);
  border-color: rgba(108, 92, 231, 0.18);
  transform: translateY(-1px);
  box-shadow: 0 2px 8px rgba(108, 92, 231, 0.08);
}

.zw-cell-ming {
  border-color: rgba(108, 92, 231, 0.3) !important;
  background: rgba(108, 92, 231, 0.06);
  box-shadow: inset 0 0 0 1px rgba(108, 92, 231, 0.1);
}

.zw-cell-shen {
  border-color: rgba(245, 158, 11, 0.25) !important;
  background: rgba(245, 158, 11, 0.04);
}

.zw-cell-center {
  grid-column: span 2;
  grid-row: span 2;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: auto;
  background: rgba(108, 92, 231, 0.03);
  border: 1px dashed rgba(108, 92, 231, 0.15);
}

/* ── 格子5层布局 ── */

/* 行1：宫位名+长生+干支 */
.zw-c-head {
  display: flex;
  align-items: center;
  gap: 2px;
  flex-wrap: wrap;
  padding-bottom: 2px;
  border-bottom: 1px solid rgba(0, 0, 0, 0.04);
  margin-bottom: 1px;
}

.zw-c-name {
  font-family: 'Noto Serif SC', serif;
  font-weight: 700;
  font-size: 10px;
  color: var(--accent, #6C5CE7);
}

.zw-c-name-ming {
  color: #E11D48;
  text-shadow: 0 0 4px rgba(225, 29, 72, 0.15);
}

.zw-c-cs {
  font-size: 9px;
  color: #8B5CF6;
  background: rgba(139, 92, 246, 0.08);
  padding: 0 3px;
  border-radius: 2px;
  font-weight: 500;
}

.zw-c-gz {
  font-size: 9px;
  color: #9CA3AF;
  margin-left: auto;
}

.zw-c-shen {
  font-size: 8px;
  background: rgba(245, 158, 11, 0.18);
  color: #D97706;
  padding: 0 3px;
  border-radius: 2px;
  font-weight: 700;
}

/* 行2：主星+亮度标注+四化 */
.zw-c-main {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 1px 3px;
  min-height: 14px;
}

.zw-ms {
  font-size: 11px;
  font-weight: 700;
  display: inline-flex;
  align-items: baseline;
  gap: 1px;
}

.zw-ms sup { font-size: 7px; font-weight: 400; opacity: 0.7; }

.zw-mb {
  font-size: 7px;
  font-weight: 500;
  opacity: 0.6;
}

/* 行3：辅星（六吉六煞+禄存天马） */
.zw-c-aux {
  display: flex;
  flex-wrap: wrap;
  gap: 1px 2px;
}

.zw-as {
  font-size: 9px;
  font-weight: 500;
  display: inline-flex;
  align-items: baseline;
  gap: 1px;
}

/* 行4：杂曜小星 */
.zw-c-minor {
  font-size: 8px;
  color: #9CA3AF;
  line-height: 1.3;
  word-break: break-all;
}

/* 行5：博士/岁前/将前十二星 */
.zw-c-small {
  font-size: 7px;
  color: #B8C0CC;
  line-height: 1.2;
  margin-top: auto;
  letter-spacing: 0.5px;
}

/* ── 亮度颜色（新缩写类名） ── */
.zw-b-miao { color: #DC2626 !important; }
.zw-b-wang { color: #EA580C !important; }
.zw-b-li   { color: #2563EB !important; }
.zw-b-ping { color: #6B7280 !important; }
.zw-b-xian { color: #B0B8C4 !important; text-decoration: line-through; opacity: 0.7; }

/* ── 四化标签（新缩写） ── */
.zw-sh {
  display: inline-block;
  font-size: 8px;
  font-weight: 700;
  padding: 0 3px;
  border-radius: 2px;
  line-height: 14px;
  vertical-align: middle;
  margin-left: 1px;
}

.zw-sh-lu   { background: rgba(34, 197, 94, 0.18); color: #16A34A; }
.zw-sh-quan { background: rgba(99, 102, 241, 0.18); color: #4F46E5; }
.zw-sh-ke   { background: rgba(14, 165, 233, 0.18); color: #0284C7; }
.zw-sh-ji   { background: rgba(239, 68, 68, 0.18); color: #DC2626; }

/* ── 中心信息区 ── */
.zw-center-box {
  text-align: center;
  padding: 8px 10px;
  width: 100%;
}

.zw-ci-row {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 8px;
  margin-bottom: 3px;
}

.zw-ci-row:last-child { margin-bottom: 0; }

.zw-ci-label {
  font-family: 'Noto Serif SC', serif;
  font-weight: 700;
  font-size: 13px;
  color: var(--accent, #6C5CE7);
}

.zw-ci-val {
  font-size: 11px;
  color: #6B7280;
  line-height: 1.5;
}

/* ── 亮度图例（保留原有 + 新四化图例） ── */
.zw-legend {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  padding-top: 8px;
  border-top: 1px dashed rgba(0, 0, 0, 0.06);
}

.zw-lg {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  font-size: 10px;
  color: #9CA3AF;
}

.zw-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  display: inline-block;
}

.zw-dot-miao { background: #DC2626; }
.zw-dot-wang { background: #EA580C; }
.zw-dot-li   { background: #2563EB; }
.zw-dot-ping { background: #9CA3AF; }
.zw-dot-xian { background: #D1D5DB; }

/* ── 模块2：命宫深度分析 ── */
.zw-ming-meta {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-bottom: 14px;
  padding: 10px 12px;
  background: rgba(108, 92, 231, 0.03);
  border-radius: 8px;
  border: 1px solid rgba(108, 92, 231, 0.08);
}

.zw-ming-meta-row {
  display: flex;
  align-items: center;
  gap: 8px;
}

.zw-mm-label {
  font-size: 12px;
  font-weight: 600;
  color: var(--accent, #6C5CE7);
  min-width: 60px;
  flex-shrink: 0;
}

.zw-mm-val {
  font-size: 12px;
  color: #4B5563;
}

.zw-star-card {
  background: rgba(255, 255, 255, 0.45);
  border: 1px solid rgba(0, 0, 0, 0.04);
  border-radius: var(--radius-md, 10px);
  padding: 12px 14px;
  margin-bottom: 10px;
  transition: all 0.2s;
}

.zw-star-card:hover {
  border-color: rgba(108, 92, 231, 0.15);
}

.zw-star-card-header {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 8px;
}

.zw-star-card-name {
  font-family: 'Noto Serif SC', serif;
  font-size: 14px;
  font-weight: 700;
  color: #1f2937;
}

.zw-star-card-bright {
  font-size: 11px;
  font-weight: 600;
  padding: 1px 6px;
  border-radius: 4px;
  background: rgba(0, 0, 0, 0.04);
}

.zw-star-card-desc {
  font-size: 13px;
  color: #4B5563;
  line-height: 1.7;
}

.zw-aux-summary {
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px dashed rgba(0, 0, 0, 0.06);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
}

.zw-aux-label {
  font-size: 12px;
  color: #6B7280;
  font-weight: 500;
}

.zw-empty-note {
  font-size: 13px;
  color: #6B7280;
  padding: 10px;
  background: rgba(0, 0, 0, 0.02);
  border-radius: 8px;
  line-height: 1.7;
}

/* ── 身宫分析 ── */
.zw-body-analysis {
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px dashed rgba(0, 0, 0, 0.06);
}

.zw-body-desc {
  font-size: 13px;
  color: #4B5563;
  line-height: 1.7;
}

/* ── 模块3：十二宫详解 ── */
.zw-palace-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.zw-palace-item {
  background: rgba(255, 255, 255, 0.4);
  border: 1px solid rgba(0, 0, 0, 0.04);
  border-radius: 8px;
  padding: 10px 12px;
  transition: all 0.2s;
}

.zw-palace-item:hover {
  background: rgba(255, 255, 255, 0.6);
  border-color: rgba(108, 92, 231, 0.12);
}

.zw-pi-ming {
  border-left: 3px solid var(--accent, #6C5CE7);
}

.zw-pi-shen {
  border-left: 3px solid #F59E0B;
}

.zw-pi-head {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
  margin-bottom: 6px;
}

.zw-pi-name {
  font-family: 'Noto Serif SC', serif;
  font-size: 13px;
  font-weight: 600;
  color: var(--accent, #6C5CE7);
}

.zw-pi-gz {
  font-size: 11px;
  color: #9CA3AF;
}

.zw-pi-cs {
  font-size: 10px;
  color: #8B5CF6;
  background: rgba(139, 92, 246, 0.08);
  padding: 0 4px;
  border-radius: 3px;
}

.zw-pi-stars {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  margin-bottom: 6px;
}

.zw-pi-empty {
  font-size: 12px;
  color: #9CA3AF;
  font-style: italic;
}

.zw-pi-aux {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  margin-bottom: 6px;
}

.zw-pi-desc {
  font-size: 12px;
  color: #6B7280;
  line-height: 1.7;
  margin: 0;
}

/* ── 模块4：四化飞星深度分析 ── */
.zw-sh-year {
  font-size: 13px;
  color: #374151;
  font-weight: 500;
  margin-bottom: 10px;
}

.zw-sh-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 8px;
  margin-bottom: 14px;
}

.zw-sh-card {
  background: rgba(255, 255, 255, 0.5);
  border: 1px solid rgba(0, 0, 0, 0.04);
  border-radius: 8px;
  padding: 10px 12px;
  text-align: center;
  transition: all 0.2s;
}

.zw-sh-card:hover { border-color: rgba(108, 92, 231, 0.15); }

.zw-sh-card-禄 { border-top: 3px solid #16A34A; }
.zw-sh-card-权 { border-top: 3px solid #4F46E5; }
.zw-sh-card-科 { border-top: 3px solid #0284C7; }
.zw-sh-card-忌 { border-top: 3px solid #DC2626; }

.zw-sh-card-type {
  font-family: 'Noto Serif SC', serif;
  font-size: 13px;
  font-weight: 700;
  margin-bottom: 4px;
}

.zw-sh-card-禄 .zw-sh-card-type { color: #16A34A; }
.zw-sh-card-权 .zw-sh-card-type { color: #4F46E5; }
.zw-sh-card-科 .zw-sh-card-type { color: #0284C7; }
.zw-sh-card-忌 .zw-sh-card-type { color: #DC2626; }

.zw-sh-card-star {
  font-size: 14px;
  font-weight: 600;
  color: #1f2937;
  margin-bottom: 2px;
}

.zw-sh-card-palace {
  font-size: 11px;
  color: #6B7280;
  margin-bottom: 6px;
}

.zw-sh-card-desc {
  font-size: 11px;
  color: #9CA3AF;
  line-height: 1.6;
  text-align: left;
  margin: 0;
}

.zw-sh-summary {
  padding-top: 12px;
  border-top: 1px dashed rgba(0, 0, 0, 0.06);
}

.zw-sh-sum-text {
  font-size: 13px;
  color: #4B5563;
  line-height: 1.8;
  margin: 0;
}

/* ── 模块5：大运流年 ── */
.zw-dy-current {
  background: linear-gradient(135deg, rgba(108, 92, 231, 0.08) 0%, rgba(168, 85, 247, 0.06) 100%);
  border: 1px solid rgba(108, 92, 231, 0.15);
  border-radius: 10px;
  padding: 12px 14px;
  margin-bottom: 14px;
}

.zw-dy-badge {
  display: inline-block;
  font-size: 10px;
  font-weight: 700;
  color: #fff;
  background: var(--accent, #6C5CE7);
  padding: 2px 8px;
  border-radius: 4px;
  margin-bottom: 6px;
}

.zw-dy-info {
  margin-bottom: 6px;
}

.zw-dy-range {
  font-family: 'Noto Serif SC', serif;
  font-size: 14px;
  font-weight: 700;
  color: #1f2937;
  margin-right: 8px;
}

.zw-dy-palace {
  font-size: 13px;
  color: #4B5563;
}

.zw-dy-sihua {
  margin-top: 6px;
  font-size: 12px;
  color: #6B7280;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
}

.zw-dy-sihua-label {
  font-weight: 500;
  color: #374151;
}

.zw-dy-sihua-item {
  display: inline-flex;
  align-items: center;
  gap: 2px;
}

.zw-dy-analysis {
  font-size: 13px;
  color: #4B5563;
  line-height: 1.7;
  margin: 8px 0 0 0;
  padding-top: 8px;
  border-top: 1px dashed rgba(0, 0, 0, 0.06);
}

.zw-dy-timeline {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 16px;
}

.zw-dy-item {
  background: rgba(255, 255, 255, 0.5);
  border: 1px solid rgba(0, 0, 0, 0.04);
  border-radius: 6px;
  padding: 6px 10px;
  text-align: center;
  min-width: 68px;
  transition: all 0.2s;
  cursor: default;
}

.zw-dy-item:hover {
  border-color: rgba(108, 92, 231, 0.2);
  background: rgba(108, 92, 231, 0.03);
}

.zw-dy-item-active {
  border-color: var(--accent, #6C5CE7);
  background: rgba(108, 92, 231, 0.06);
  box-shadow: 0 0 0 1px rgba(108, 92, 231, 0.15);
}

.zw-dy-age {
  font-size: 11px;
  font-weight: 700;
  color: #1f2937;
}

.zw-dy-gz {
  font-size: 10px;
  color: var(--accent, #6C5CE7);
  font-weight: 500;
}

.zw-dy-pname {
  font-size: 9px;
  color: #9CA3AF;
}

/* 流年 */
.zw-ln-section {
  padding-top: 12px;
  border-top: 1px dashed rgba(0, 0, 0, 0.06);
}

.zw-ln-sihua {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 8px;
}

.zw-ln-tag {
  font-size: 12px;
  color: #374151;
  display: inline-flex;
  align-items: center;
  gap: 3px;
}

.zw-ln-analysis {
  font-size: 13px;
  color: #4B5563;
  line-height: 1.7;
  margin: 0;
}

/* ── 模块6：格局识别 ── */
.zw-pat-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.zw-pat-item {
  border-radius: 8px;
  padding: 10px 12px;
  border-left: 3px solid;
  transition: all 0.2s;
}

.zw-pat-item:hover { transform: translateX(2px); }

.zw-pat-good {
  background: rgba(34, 197, 94, 0.06);
  border-left-color: #16A34A;
}

.zw-pat-mid {
  background: rgba(99, 102, 241, 0.06);
  border-left-color: #6366F1;
}

.zw-pat-bad {
  background: rgba(239, 68, 68, 0.06);
  border-left-color: #DC2626;
}

.zw-pat-head {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 4px;
}

.zw-pat-name {
  font-family: 'Noto Serif SC', serif;
  font-size: 13px;
  font-weight: 700;
  color: #1f2937;
}

.zw-pat-level {
  font-size: 10px;
  font-weight: 600;
  padding: 1px 6px;
  border-radius: 3px;
  background: rgba(0, 0, 0, 0.05);
  color: #6B7280;
}

.zw-pat-good .zw-pat-level { background: rgba(34, 197, 94, 0.12); color: #16A34A; }
.zw-pat-bad .zw-pat-level  { background: rgba(239, 68, 68, 0.12); color: #DC2626; }
.zw-pat-mid .zw-pat-level  { background: rgba(99, 102, 241, 0.12); color: #4F46E5; }

.zw-pat-desc {
  font-size: 12px;
  color: #6B7280;
  line-height: 1.6;
  margin: 0;
}

/* ── 模块7：健康分析 ── */
.zw-health {
  padding: 10px 12px;
  background: rgba(255, 255, 255, 0.4);
  border: 1px solid rgba(0, 0, 0, 0.04);
  border-radius: 8px;
}

.zw-health-head {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
  margin-bottom: 8px;
}

.zw-health-label {
  font-family: 'Noto Serif SC', serif;
  font-size: 13px;
  font-weight: 600;
  color: var(--accent, #6C5CE7);
}

.zw-health-gz {
  font-size: 11px;
  color: #9CA3AF;
}

.zw-health-desc {
  font-size: 13px;
  color: #4B5563;
  line-height: 1.7;
  margin: 0;
}

/* ── 模块8：事业与财运 ── */
.zw-cw-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
}

.zw-cw-item {
  background: rgba(255, 255, 255, 0.45);
  border: 1px solid rgba(0, 0, 0, 0.04);
  border-radius: 8px;
  padding: 12px;
  transition: all 0.2s;
}

.zw-cw-item:hover {
  border-color: rgba(108, 92, 231, 0.12);
}

.zw-cw-head {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 8px;
}

.zw-cw-label {
  font-family: 'Noto Serif SC', serif;
  font-size: 13px;
  font-weight: 600;
  color: var(--accent, #6C5CE7);
}

.zw-cw-gz {
  font-size: 11px;
  color: #9CA3AF;
}

.zw-cw-stars {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  margin-bottom: 8px;
}

.zw-cw-desc {
  font-size: 12px;
  color: #6B7280;
  line-height: 1.7;
  margin: 0;
}

/* ── 模块9：感情婚姻 ── */
.zw-marriage {
  padding: 10px 12px;
  background: rgba(255, 255, 255, 0.4);
  border: 1px solid rgba(0, 0, 0, 0.04);
  border-radius: 8px;
}

.zw-marriage-head {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
  margin-bottom: 8px;
}

.zw-marriage-label {
  font-family: 'Noto Serif SC', serif;
  font-size: 13px;
  font-weight: 600;
  color: var(--accent, #6C5CE7);
}

.zw-marriage-gz {
  font-size: 11px;
  color: #9CA3AF;
}

.zw-marriage-desc {
  font-size: 13px;
  color: #4B5563;
  line-height: 1.7;
  margin: 0;
}

/* ── 模块10：综合论断与建议 ── */
.zw-sum-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
  margin-bottom: 14px;
}

.zw-sum-item {
  background: rgba(255, 255, 255, 0.4);
  border-radius: 8px;
  padding: 10px 12px;
  border: 1px solid rgba(0, 0, 0, 0.03);
  transition: all 0.2s;
}

.zw-sum-item:hover {
  border-color: rgba(108, 92, 231, 0.12);
}

.zw-sum-label {
  font-family: 'Noto Serif SC', serif;
  font-size: 12px;
  font-weight: 600;
  color: var(--accent, #6C5CE7);
  margin-bottom: 6px;
  display: block;
}

.zw-sum-text {
  font-size: 13px;
  color: #4B5563;
  line-height: 1.8;
  margin: 0;
}

.zw-advice {
  padding-top: 14px;
  border-top: 1px dashed rgba(0, 0, 0, 0.06);
}

.zw-advice-text {
  font-size: 13px;
  color: #4B5563;
  line-height: 1.8;
  margin: 0;
}

/* ── 移动端适配 ── */
@media (max-width: 640px) {
  .zw-grid {
    gap: 2px;
    min-width: 440px;
  }
  .zw-cell {
    padding: 3px 4px;
    min-height: 75px;
  }
  .zw-c-name { font-size: 9px; }
  .zw-ms { font-size: 10px; }
  .zw-as { font-size: 8px; }
  .zw-c-minor { font-size: 7px; }
  .zw-c-small { font-size: 6px; }
  .zw-sh { font-size: 7px; padding: 0 2px; }
  .zw-sh-grid { grid-template-columns: 1fr; }
  .zw-dy-item { min-width: 58px; padding: 4px 6px; }
  .zw-cw-grid { grid-template-columns: 1fr; }
  .zw-sum-grid { grid-template-columns: 1fr; }
}

@media (max-width: 380px) {
  .zw-grid { min-width: 360px; }
  .zw-cell { min-height: 65px; padding: 2px 3px; }
  .zw-c-head { gap: 1px; }
  .zw-c-main { gap: 1px 2px; }
  .zw-mb { display: none; }
  .zw-c-small { display: none; }
}

