/* ================================================================
   数慧岐黄 · 命理计算系统  —  主样式表
   支持 Dark / Light 双主题（data-theme 属性切换）
   ================================================================ */

/* ── 暗色主题（默认）── */
:root,
[data-theme="dark"] {
  --bg-1: #07101d;
  --bg-2: #0f223f;
  --bg-3: #0f2850;
  --panel: rgba(9,20,38,.78);
  --text: #ecf4ff;
  --muted: #a7b7d3;
  --accent: #48d4ff;
  --accent-2: #3e86ff;
  --gold: #ffcb57;
  --orange: #ff9a3c;
  --danger: #ff6b6b;
  /* 主题面 */
  --surface-1: rgba(255,255,255,.03);
  --surface-2: rgba(255,255,255,.05);
  --surface-3: rgba(255,255,255,.09);
  --surface-hover: rgba(255,255,255,.07);
  --border-1: rgba(255,255,255,.06);
  --border-2: rgba(255,255,255,.09);
  --border-3: rgba(255,255,255,.13);
  --border-dash: rgba(255,255,255,.08);
  /* 组件专属 */

  --topbar-bg: linear-gradient(180deg,rgba(7,18,37,.9),rgba(7,18,37,.6));
  --topbar-border: rgba(255,255,255,.07);
  --glass-shadow: 0 12px 44px rgba(0,0,0,.28);
  --card-glow: 0 0 0 1px rgba(255,255,255,.04);
  --offcanvas-bg: linear-gradient(180deg,#07162c,#091a34);
  --form-bg: rgba(255,255,255,.06);
  --form-bg-focus: rgba(255,255,255,.09);
  --form-border: rgba(255,255,255,.09);
  --form-text: #fff;
  --scrollbar-track: rgba(255,255,255,.04);
  --scrollbar-thumb: rgba(255,255,255,.18);
  --scrollbar-hover: rgba(255,255,255,.3);
  --glow-a: rgba(255,176,92,.13);
  --glow-b: rgba(72,212,255,.12);
  --bg-grad: linear-gradient(135deg,var(--bg-1),var(--bg-2) 48%,var(--bg-3));
}

/* ── 亮色主题 ── */
[data-theme="light"] {
  --bg-1: #eef2f9;
  --bg-2: #dde5f3;
  --bg-3: #cdd8ee;
  --panel: rgba(255,255,255,.88);
  --text: #1c2b45;
  --muted: #5e7394;
  --accent: #0a7fc4;
  --accent-2: #1d62cc;
  --gold: #b8720a;
  --orange: #bf5f0a;
  --danger: #cc2222;
  --surface-1: rgba(0,0,0,.028);
  --surface-2: rgba(0,0,0,.05);
  --surface-3: rgba(0,0,0,.08);
  --surface-hover: rgba(0,0,0,.045);
  --border-1: rgba(0,0,0,.07);
  --border-2: rgba(0,0,0,.1);
  --border-3: rgba(0,0,0,.14);
  --border-dash: rgba(0,0,0,.1);

  --topbar-bg: linear-gradient(180deg,rgba(250,252,255,.96),rgba(248,251,255,.82));
  --topbar-border: rgba(0,0,0,.08);
  --glass-shadow: 0 8px 32px rgba(0,0,0,.1),0 2px 8px rgba(0,0,0,.06);
  --card-glow: 0 0 0 1px rgba(0,0,0,.04);
  --offcanvas-bg: linear-gradient(180deg,#f5f8ff,#eef3ff);
  --form-bg: rgba(0,0,0,.04);
  --form-bg-focus: rgba(0,0,0,.06);
  --form-border: rgba(0,0,0,.1);
  --form-text: #1c2b45;
  --scrollbar-track: rgba(0,0,0,.06);
  --scrollbar-thumb: rgba(0,0,0,.2);
  --scrollbar-hover: rgba(0,0,0,.34);
  --glow-a: rgba(255,160,60,.09);
  --glow-b: rgba(10,127,196,.09);
  --bg-grad: linear-gradient(135deg,var(--bg-1),var(--bg-2) 48%,var(--bg-3));
}

/* ================================================================
   基础 / 全局
   ================================================================ */
*,*::before,*::after { box-sizing: border-box; }
html,body { height: 100%; overflow-x: hidden; }

/* 主题切换时平滑过渡 */
body,
.topbar,.glass-card,.offcanvas,
.form-control,.form-select,.analysis-box,.chat-log,
.module-item,.fortune-chip,.bazi-grid-wrap,.case-item,
.mini-stat,.btn-outline-light,.chat-item,.info-grid div,
.bazi-stem,.bazi-branch,.bazi-hidden,.bazi-ten-god,
.elem-track,.dayun-chip,.pill-inline,.case-list,.table-dark {
  transition:
    background-color .3s ease,
    border-color .3s ease,
    color .3s ease,
    box-shadow .3s ease;
}

body {
  margin: 0;
  color: var(--text);
  background:
    radial-gradient(circle at 12% 18%,var(--glow-a),transparent 16%),
    radial-gradient(circle at 76% 20%,var(--glow-b),transparent 18%),
    var(--bg-grad);
  font-family: "PingFang SC","Microsoft YaHei",system-ui,-apple-system,sans-serif;
}
.app-shell { min-height: 100vh; }
.app-shell > main { min-width: 0; }

/* 自定义滚动条 */
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: var(--scrollbar-track); border-radius: 99px; }
::-webkit-scrollbar-thumb { background: var(--scrollbar-thumb); border-radius: 99px; }
::-webkit-scrollbar-thumb:hover { background: var(--scrollbar-hover); }



/* ================================================================
   顶栏
   ================================================================ */
.topbar {
  position: sticky; top: 0; z-index: 20;
  backdrop-filter: blur(20px) saturate(180%);
  -webkit-backdrop-filter: blur(20px) saturate(180%);
  background: var(--topbar-bg);
  border-bottom: 1px solid var(--topbar-border);
}
.topbar-main { min-width: 0; }
.topbar-toggle { display: none; margin-top: .65rem; }
.topbar-extra { transition: opacity .25s ease; }
.eyebrow { color: var(--accent); letter-spacing: .12rem; font-size: .82rem; margin-bottom: .25rem; }

/* 主题切换按钮 */
.theme-toggle-btn {
  width: 36px; height: 36px; border-radius: 50%;
  border: 1px solid var(--border-2); background: var(--surface-2);
  color: var(--text); cursor: pointer;
  display: grid; place-items: center; font-size: 1rem; flex-shrink: 0;
  transition: background .2s,border-color .2s,transform .2s,box-shadow .2s;
}
.theme-toggle-btn:hover {
  background: var(--surface-3); border-color: var(--accent);
  transform: rotate(25deg) scale(1.1);
  box-shadow: 0 0 14px rgba(72,212,255,.28);
}

/* ── 顶栏品牌 & 状态指示 ── */
.topbar { height: 62px; }
.topbar-brand { display: flex; align-items: center; gap: .75rem; }
.topbar-logo-img {
  height: 34px; width: auto; max-width: 120px; object-fit: contain; flex-shrink: 0;border-radius: 7px;
}
.topbar-logo-mark {
  width: 34px; height: 34px; border-radius: 10px; flex-shrink: 0;
  display: grid; place-items: center; font-size: .95rem; font-weight: 700;
  background: linear-gradient(145deg, var(--accent-2), var(--accent));
  color: #fff; box-shadow: 0 4px 12px rgba(62,134,255,.28);
}
.topbar-brand-text { display: flex; flex-direction: column; line-height: 1.25; }
.topbar-name { font-size: .9rem; font-weight: 700; color: var(--text); }
.topbar-sub { font-size: .68rem; color: var(--muted); letter-spacing: .04em; }
.topbar-sep { width: 1px; height: 22px; background: var(--border-2); flex-shrink: 0; }
.topbar-status { display: flex; align-items: center; gap: .45rem; font-size: .78rem; color: var(--muted); }
.status-dot {
  width: 7px; height: 7px; border-radius: 50%; flex-shrink: 0;
  background: #52c41a; box-shadow: 0 0 6px rgba(82,196,26,.5);
}
.status-dot.error { background: var(--danger); box-shadow: 0 0 6px rgba(255,107,107,.5); }
.status-dot.loading {
  background: var(--gold); box-shadow: 0 0 6px rgba(255,203,87,.5);
  animation: statusBlink .9s infinite;
}
@keyframes statusBlink { 0%,100% { opacity:1; } 50% { opacity:.3; } }

/* ================================================================
   Glass 卡片
   ================================================================ */
.glass-card {
  background: var(--panel);
  border: 1px solid var(--border-1);
  border-radius: 24px;
  backdrop-filter: blur(20px) saturate(160%);
  -webkit-backdrop-filter: blur(20px) saturate(160%);
  box-shadow: var(--glass-shadow),var(--card-glow);
  padding: 1.25rem;
  transition: box-shadow .25s,border-color .25s,transform .25s;
}
.panel-title {
  font-size: 1rem; font-weight: 700; color: var(--text);
  padding-left: .62rem; border-left: 2.5px solid var(--accent);
  line-height: 1.4; display: inline-flex; align-items: center;
}
.panel-title--sm {
  font-size: .96rem;
}
.side-panel-head {
  padding-bottom: .8rem;
  border-bottom: 1px solid var(--border-1);
}
.side-panel-head .panel-title {
  margin-bottom: 0;
}

/* 面板头部布局 */
.panel-header {
  display: flex; justify-content: space-between; align-items: center;
  flex-wrap: wrap; gap: .75rem;
}

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

.birthplace-field {
  display: flex;
  flex-direction: column;
  gap: .35rem;
  position: relative;
}

.region-combobox {
  position: relative;
}

.region-search-input {
  padding-right: 2.6rem;
}

.region-search-input[disabled] {
  cursor: not-allowed;
}

.region-combobox-toggle {
  position: absolute;
  top: 50%;
  right: .55rem;
  transform: translateY(-50%);
  width: 1.8rem;
  height: 1.8rem;
  border: 0;
  border-radius: 999px;
  background: transparent;
  color: var(--muted);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background .18s ease, color .18s ease, transform .18s ease;
}

.region-combobox-toggle:hover:not(:disabled) {
  background: var(--surface-2);
  color: var(--text);
}

.region-combobox.is-open .region-combobox-toggle {
  transform: translateY(-50%) rotate(180deg);
  color: var(--accent);
}

.region-combobox-toggle:disabled {
  opacity: .45;
  cursor: not-allowed;
}

.region-option-list {
  position: absolute;
  top: calc(100% + .35rem);
  left: 0;
  right: 0;
  z-index: 12;
  display: none;
  max-height: 14rem;
  overflow-y: auto;
  padding: .35rem;
  border-radius: 16px;
  border: 1px solid var(--border-2);
  background: color-mix(in srgb, var(--panel) 92%, transparent);
  backdrop-filter: blur(18px) saturate(150%);
  -webkit-backdrop-filter: blur(18px) saturate(150%);
  box-shadow: 0 18px 36px rgba(0,0,0,.22);
}

.region-option-list.is-open {
  display: block;
}

.region-option-item,
.region-option-empty {
  width: 100%;
  border: 0;
  background: transparent;
  color: var(--text);
  text-align: left;
  border-radius: 12px;
  padding: .68rem .78rem;
}

.region-option-item {
  cursor: pointer;
  transition: background .18s ease, color .18s ease, transform .18s ease;
}

.region-option-item:hover,
.region-option-item.is-active {
  background: linear-gradient(135deg, rgba(72,212,255,.16), rgba(255,203,87,.1));
  color: var(--text);
}

.region-option-item small,
.region-option-empty small {
  display: block;
  margin-top: .18rem;
  color: var(--muted);
}

.region-match-highlight {
  padding: 0 .18em;
  border-radius: .35rem;
  background: rgba(255, 203, 87, .22);
  color: inherit;
}

.region-option-empty {
  cursor: default;
}

.region-select-proxy {
  display: none;
}

.region-search-input::-webkit-search-cancel-button {
  cursor: pointer;
}

@media (max-width: 767.98px) {
  .birthplace-grid {
    grid-template-columns: 1fr;
  }

  .region-option-list {
    max-height: 18rem;
    padding: .42rem;
  }

  .region-option-item,
  .region-option-empty {
    padding: .9rem .92rem;
    min-height: 3.25rem;
  }

  .region-option-item small,
  .region-option-empty small {
    margin-top: .24rem;
    font-size: .78rem;
  }
}
/* 命主标签 */
.profile-tag {
  display: inline-flex; align-items: center;
  padding: .18rem .6rem; border-radius: 999px;
  font-size: .72rem; font-weight: 600; white-space: nowrap;
  background: rgba(72,212,255,.1); border: 1px solid rgba(72,212,255,.2); color: var(--accent);
  transition: background .2s, color .2s;
  max-width: min(100%, 260px);
  overflow: hidden;
  text-overflow: ellipsis;
}
[data-theme="light"] .profile-tag {
  background: rgba(10,127,196,.08); border-color: rgba(10,127,196,.18);
}
/* 侧面板标签导航 */
.side-tabs {
  display: flex; gap: .3rem;
  background: var(--surface-1); border: 1px solid var(--border-1);
  border-radius: 14px; padding: .3rem;
}
.side-tab {
  flex: 1; display: flex; align-items: center; justify-content: center; gap: .35rem;
  border: 0; background: transparent; color: var(--muted);
  border-radius: 10px; padding: .48rem .5rem;
  font-size: .78rem; font-weight: 600; cursor: pointer; white-space: nowrap;
  transition: background .18s, color .18s, box-shadow .18s;
}
.side-tab:hover { color: var(--text); background: var(--surface-2); }
.side-tab.active {
  color: var(--text); background: var(--surface-3);
  box-shadow: 0 1px 6px rgba(0,0,0,.14);
}
.side-tab i { font-size: .88rem; flex-shrink: 0; }
[data-theme="light"] .side-tab.active {
  background: rgba(0,0,0,.07); box-shadow: 0 1px 4px rgba(0,0,0,.1);
}
.view-toolbar { align-items: center; }
/* 两行工具栏 */
.view-toolbar-wrap {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: flex-end;
  align-items: center;
  width: 100%;
  gap: .55rem .75rem;
}
.view-toolbar-row {
  display: flex; align-items: center; gap: .45rem;
}
.view-toolbar-row--main { justify-content: flex-end; width: 100%; flex-wrap: wrap; }
.view-toolbar-row--layers { justify-content: flex-end; }
.toolbar-label {
  font-size: .72rem; font-weight: 600; letter-spacing: .06em;
  color: var(--muted); opacity: .75; white-space: nowrap;
}
.fortune-mode-group {
  display: inline-flex;
  align-items: center;
  gap: .3rem;
  padding: .22rem;
  border-radius: 999px;
  background: linear-gradient(180deg, var(--surface-1), rgba(255,255,255,.01));
  border: 1px solid var(--border-1);
  min-width: 0;
}
.fortune-mode-btn {
  border: 0;
  background: transparent;
  color: var(--muted);
  border-radius: 999px;
  padding: .4rem .72rem;
  min-height: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  text-align: center;
  cursor: pointer;
  opacity: .78;
  transition: background .22s,color .22s,transform .22s,box-shadow .22s,border-color .22s;
}
.fortune-mode-btn.is-primary {
  box-shadow: inset 0 0 0 1px rgba(255,203,87,.14);
}
.fortune-mode-btn strong {
  font-size: .82rem;
  font-weight: 700;
  color: var(--text);
  letter-spacing: .02em;
  line-height: 1;
}
.fortune-mode-kicker {
  display: none;
}
.fortune-mode-desc {
  display: none;
}
.fortune-mode-btn:hover {
  background: var(--surface-2);
  color: var(--text);
  opacity: .96;
  transform: translateY(-1px);
}
.fortune-mode-btn.active {
  background: linear-gradient(145deg, rgba(72,212,255,.18), rgba(255,203,87,.12));
  box-shadow: inset 0 0 0 1px rgba(72,212,255,.16), 0 8px 18px rgba(0,0,0,.12);
  color: var(--text);
  opacity: 1;
  transform: translateY(-1px) scale(1.01);
}
.fortune-mode-btn.active .fortune-mode-kicker,
.fortune-mode-btn.active .fortune-mode-desc {
  color: var(--text);
  opacity: .86;
}
[data-theme="light"] .fortune-mode-group {
  background: linear-gradient(180deg, rgba(255,255,255,.7), rgba(255,255,255,.4));
}
[data-theme="light"] .fortune-mode-btn.is-primary {
  box-shadow: inset 0 0 0 1px rgba(184,114,10,.12);
}
[data-theme="light"] .fortune-mode-btn.active {
  background: linear-gradient(145deg, rgba(10,127,196,.12), rgba(184,114,10,.1));
  box-shadow: inset 0 0 0 1px rgba(10,127,196,.12), 0 8px 16px rgba(61,88,126,.08);
}
.toolbar-sep { width: 1px; height: 1.2rem; background: var(--border-1); margin: 0 .1rem; }
.glass-card > .d-flex.justify-content-between.align-items-center.mb-3.flex-wrap.gap-2 { margin-bottom: 1rem !important; }
.layer-toggle-group {
  display: inline-flex; align-items: center; gap: .4rem; flex-wrap: wrap;
  padding: .3rem; border-radius: 999px; background: var(--surface-1); border: 1px solid var(--border-1);
}
.layer-toggle-btn {
  border: 0; background: transparent; color: var(--muted); border-radius: 999px;
  padding: .38rem .78rem; font-size: .78rem; font-weight: 600; letter-spacing: .02em;
  transition: background .22s,color .22s,transform .22s,box-shadow .22s;
}
.layer-toggle-btn:hover { color: var(--text); background: var(--surface-2); transform: translateY(-1px); }
.layer-toggle-btn.active {
  color: var(--text); background: linear-gradient(135deg, rgba(72,212,255,.18), rgba(255,203,87,.14));
  box-shadow: inset 0 0 0 1px rgba(72,212,255,.16);
}
[data-theme="light"] .layer-toggle-btn.active {
  background: linear-gradient(135deg, rgba(10,127,196,.12), rgba(184,114,10,.12));
  box-shadow: inset 0 0 0 1px rgba(10,127,196,.12);
}
.text-secondary { color: var(--muted) !important; }
.badge-accent { background: rgba(72,212,255,.16); color: var(--accent); border: 1px solid rgba(72,212,255,.2); }

/* ================================================================
   表单
   ================================================================ */
.form-control,.form-select {
  background: var(--form-bg); border-color: var(--form-border);
  color: var(--form-text); border-radius: 12px;
}
.form-control::placeholder { color: var(--muted); }
.form-control:focus,.form-select:focus {
  background: var(--form-bg-focus); color: var(--form-text);
  border-color: var(--accent); box-shadow: 0 0 0 .2rem rgba(72,212,255,.14);
}
.form-label { color: var(--muted); font-size: .88rem; margin-bottom: .35rem; }
.form-section-caption {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  font-size: .76rem;
  font-weight: 700;
  letter-spacing: .08em;
  color: var(--accent);
  margin-top: .2rem;
  text-transform: uppercase;
}
.form-section-caption::before {
  content: '';
  width: 18px;
  height: 1px;
  background: currentColor;
  opacity: .55;
}
.advanced-options {
  border: 1px solid var(--border-1);
  border-radius: 14px;
  background: var(--surface-1);
  padding: .82rem .9rem;
}
.advanced-options summary {
  list-style: none;
  cursor: pointer;
  font-size: .8rem;
  font-weight: 700;
  color: var(--muted);
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.advanced-options summary::-webkit-details-marker {
  display: none;
}
.advanced-options summary::after {
  content: '\25BE';
  font-size: .72rem;
  transition: transform .18s ease;
}
.advanced-options[open] summary::after {
  transform: rotate(180deg);
}
.advanced-options-body {
  padding-top: .55rem;
}
.form-check-input { background-color: var(--form-bg); border-color: var(--border-2); }
.form-check-label { color: var(--text); }
.form-select option { color: #111; background: #fff; }

/* ================================================================
   按钮
   ================================================================ */
.btn { border-radius: 12px; font-weight: 500; transition: transform .15s,box-shadow .15s,background .2s,border-color .2s; }
.btn:active { transform: scale(.96) !important; }
.btn-primary {
  background: linear-gradient(135deg,var(--accent-2),var(--accent));
  border: none; color: #fff;
  box-shadow: 0 4px 16px rgba(72,212,255,.2);
}
.btn-primary:hover {
  background: linear-gradient(135deg,#2a6ee0,#5ae2ff);
  box-shadow: 0 6px 22px rgba(72,212,255,.38);
  transform: translateY(-1px); color: #fff;
}
.btn-outline-light {
  border-color: var(--border-2); color: var(--text); background: var(--surface-1);
}
.btn-outline-light:hover {
  background: var(--surface-3); border-color: var(--accent);
  color: var(--accent); transform: translateY(-1px);
}

/* ================================================================
   命盘主视图
   ================================================================ */
.mingli-stage {
  padding: clamp(1.1rem,2.2vw,1.9rem) clamp(1rem,2vw,1.4rem) clamp(1.5rem,2.8vw,2.2rem);
  min-height: min(760px,76vh);
  overflow: hidden;
  border: 1px solid var(--border-1);
  border-radius: 32px;
  background:
    radial-gradient(circle at 12% 18%, rgba(255,203,87,.09), transparent 26%),
    radial-gradient(circle at 86% 14%, rgba(72,212,255,.08), transparent 24%),
    linear-gradient(180deg, var(--surface-2), rgba(255,255,255,0));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.18), 0 24px 60px rgba(8,20,42,.08);
}
.mingli-stage::before {
  content: '';
  position: absolute;
  inset: 20px;
  border-radius: 24px;
  border: 1px solid var(--border-dash);
  pointer-events: none;
}
.mingli-stage::after {
  content: '';
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, transparent 0, rgba(255,255,255,.12) 50%, transparent 100%),
    linear-gradient(0deg, transparent 0, rgba(255,255,255,.06) 50%, transparent 100%);
  mask: radial-gradient(circle at center, transparent 0 41%, black 42%);
  opacity: .3;
  pointer-events: none;
}
.canvas-wrap {
  width: min(100%,742px);
  aspect-ratio: 1/1;
  position: relative;
  margin-top: .4rem;
  padding: clamp(12px,1.4vw,16px);
  border-radius: 50%;
  background: radial-gradient(circle at 50% 46%, rgba(255,255,255,.5), rgba(255,255,255,.08) 58%, rgba(255,255,255,0) 74%);
  box-shadow: inset 0 0 0 1px var(--border-1), inset 0 0 36px rgba(72,212,255,.06), 0 20px 44px rgba(8,20,42,.1);
}
.canvas-wrap::before,
.canvas-wrap::after {
  content: '';
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
}
.canvas-wrap::before {
  inset: 6px;
  border: 1px solid var(--border-2);
}
.canvas-wrap::after {
  inset: 18px;
  border: 1px dashed var(--border-dash);
  opacity: .55;
}
#astrolabeCanvas {
  width: 100%;
  height: 100%;
  display: block;
  border-radius: 50%;
  filter: drop-shadow(0 14px 40px rgba(72,212,255,.1));
}
.mingli-stage.is-shifting .canvas-wrap { animation: plateShift .72s cubic-bezier(.22,.8,.24,1); }
.mingli-stage.is-shifting #astrolabeCanvas { animation: canvasGlow .72s ease-out; }
.star-glow { position: absolute; border-radius: 50%; filter: blur(14px); opacity: .5; pointer-events: none; }
.glow-1 { width: 160px; height: 160px; background: rgba(255,191,94,.22); left: 3%; top: 10%; }
.glow-2 { width: 120px; height: 120px; background: rgba(72,212,255,.16); right: 8%; top: 20%; }
[data-theme="light"] .glow-1 { background: rgba(184,114,10,.16); }
[data-theme="light"] .glow-2 { background: rgba(10,127,196,.12); }
[data-theme="light"] .mingli-stage {
  background:
    radial-gradient(circle at 12% 18%, rgba(184,114,10,.12), transparent 26%),
    radial-gradient(circle at 86% 14%, rgba(10,127,196,.1), transparent 24%),
    linear-gradient(180deg, rgba(255,255,255,.82), rgba(255,255,255,.36));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.75), 0 20px 54px rgba(110,136,172,.14);
}
[data-theme="light"] .mingli-stage::after { opacity: .18; }
[data-theme="light"] .canvas-wrap {
  background: radial-gradient(circle at 50% 46%, rgba(255,255,255,.92), rgba(255,255,255,.46) 58%, rgba(255,255,255,0) 74%);
  box-shadow: inset 0 0 0 1px var(--border-1), inset 0 0 26px rgba(10,127,196,.06), 0 16px 36px rgba(110,136,172,.16);
}

@keyframes plateShift {
  0% { transform: scale(.986) rotate(-.45deg); }
  40% { transform: scale(1.008) rotate(.2deg); }
  100% { transform: scale(1) rotate(0deg); }
}

@keyframes canvasGlow {
  0% { filter: drop-shadow(0 0 0 rgba(72,212,255,0)); opacity: .94; }
  38% { filter: drop-shadow(0 14px 34px rgba(72,212,255,.18)); opacity: 1; }
  100% { filter: drop-shadow(0 14px 40px rgba(72,212,255,.1)); opacity: 1; }
}

@media (max-width: 991.98px) {
  .view-toolbar { gap: .55rem !important; }
  .mingli-stage { min-height: auto; padding-bottom: 1.35rem; }
  .canvas-wrap { width: min(100%,680px); }
}

@media (max-width: 767.98px) {
  .view-toolbar-wrap {
    width: 100%;
    justify-content: flex-start;
  }
  .view-toolbar-row {
    flex-wrap: wrap;
    width: 100%;
  }
  .view-toolbar-row--main {
    align-items: center;
  }
  .fortune-mode-group {
    width: 100%;
    min-width: 0;
    justify-content: space-between;
  }
  .fortune-mode-btn {
    flex: 1 1 0;
    min-height: 0;
    padding-inline: .58rem;
  }
  .layer-toggle-group { width: 100%; justify-content: center; border-radius: 18px; }
  .layer-toggle-btn { flex: 1 1 auto; text-align: center; }
  .canvas-wrap { width: min(100%,620px); }
}

.mini-stat {
  border: 1px solid var(--border-1); border-radius: 18px; padding: .9rem 1rem;
  background: var(--surface-1); transition: box-shadow .2s,transform .2s,border-color .2s;
}
.mini-stat:hover { transform: translateY(-2px); box-shadow: 0 6px 20px rgba(0,0,0,.12); border-color: var(--border-2); }
.mini-stat--primary {
  background: linear-gradient(180deg, var(--surface-2), var(--surface-1));
  border-color: var(--border-2);
}
.mini-stat--primary .value {
  font-size: 1.08rem;
}
.mini-stat--secondary {
  background: var(--surface-1);
  opacity: .96;
}
.mini-stat .label { font-size: .8rem; color: var(--muted); margin-bottom: .25rem; }
.mini-stat .value { font-size: 1.02rem; font-weight: 700; }

.info-grid { display: grid; gap: .75rem; }
.info-grid div {
  display: flex; justify-content: space-between; gap: 1rem; align-items: center;
  border-bottom: 1px dashed var(--border-dash); padding-bottom: .55rem;
}
.side-panel-body-note {
  font-size: .76rem;
  color: var(--muted);
}
.info-grid span { color: var(--muted); }

.module-item,.fortune-chip {
  display: flex; align-items: center; gap: .75rem; padding: .85rem 1rem;
  border-radius: 16px; background: var(--surface-1); border: 1px solid var(--border-1);
  transition: background .2s,border-color .2s,box-shadow .2s,transform .2s;
}
.module-item:hover { background: var(--surface-2); border-color: var(--border-2); transform: translateY(-1px); }
.module-item i { color: var(--accent); font-size: 1.1rem; }

.analysis-box {
  min-height: 320px; border-radius: 18px;
  background: var(--surface-1); border: 1px solid var(--border-1);
  padding: 1rem 1rem .4rem; line-height: 1.85; color: var(--text);
  position: relative;
  transition: max-height .24s ease, box-shadow .24s ease, background-color .3s ease, border-color .3s ease, color .3s ease;
}
.analysis-box p:last-child { margin-bottom: 0; }
.analysis-box--collapsed {
  max-height: 30rem;
  overflow: hidden;
}
.analysis-box--collapsed::after {
  content: '';
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 5.5rem;
  pointer-events: none;
  background: linear-gradient(180deg, rgba(7,16,29,0), rgba(7,16,29,.88));
  border-radius: 0 0 18px 18px;
}
[data-theme="light"] .analysis-box--collapsed::after {
  background: linear-gradient(180deg, rgba(245,248,255,0), rgba(245,248,255,.95));
}
.analysis-top-actions {
  display: flex;
  align-items: center;
  gap: .45rem;
  flex-wrap: wrap;
  justify-content: flex-end;
}
.analysis-top-actions .btn:disabled {
  opacity: .5;
  transform: none !important;
  cursor: not-allowed;
}

.timeline-lite { display: grid; gap: .85rem; }
.timeline-lite .step { display: grid; grid-template-columns: 48px 1fr; gap: .9rem; align-items: start; }
.timeline-lite .step > span {
  width: 40px; height: 40px; border-radius: 14px; display: grid; place-items: center;
  background: linear-gradient(135deg,rgba(72,212,255,.22),rgba(62,134,255,.36)); color: white; font-weight: 700;
}
.timeline-lite p { margin: .2rem 0 0; color: var(--muted); }

.table-dark {
  --bs-table-bg: transparent;
  --bs-table-striped-bg: var(--surface-1);
  --bs-table-hover-bg: var(--surface-2);
  --bs-table-color: var(--text);
  --bs-table-striped-color: var(--text);
  --bs-table-hover-color: var(--text);
  --bs-table-border-color: var(--border-1);
}
[data-theme="light"] .table-dark td,
[data-theme="light"] .table-dark th { color: var(--text) !important; border-color: var(--border-1) !important; }

.offcanvas { width: min(480px,94vw) !important; background: var(--offcanvas-bg) !important; color: var(--text); }
.offcanvas-header { border-bottom-color: var(--border-2) !important; }
.offcanvas-title { color: var(--text) !important; }
[data-theme="light"] .btn-close-white { filter: none; }

#chatDrawer .offcanvas-body {
  min-height: 0;
  height: calc(100vh - 63px);
  overflow: hidden;
}

.chat-log {
  flex: 1 1 auto;
  min-height: 0;
  max-height: none;
  overflow: auto;
  border: 1px solid var(--border-2); border-radius: 18px;
  padding: 1rem; background: var(--surface-1);
}
.chat-item { padding: .75rem 1rem; border-radius: 16px; margin-bottom: .75rem; line-height: 1.7; }
.chat-item.assistant { background: rgba(62,134,255,.12); border: 1px solid rgba(62,134,255,.16); }
.chat-item.user { background: var(--surface-2); border: 1px solid var(--border-1); text-align: right; }
.chat-composer {
  flex: 0 0 auto;
  margin-top: auto;
  padding-top: .8rem;
  border-top: 1px solid var(--border-1);
  background: linear-gradient(180deg, rgba(7,22,44,0), rgba(7,22,44,.72) 18%, rgba(7,22,44,.96));
  backdrop-filter: blur(10px);
}
[data-theme="light"] .chat-composer {
  background: linear-gradient(180deg, rgba(245,248,255,0), rgba(245,248,255,.9) 18%, rgba(238,243,255,.98));
  border-top-color: rgba(0,0,0,.08);
}
.chat-composer-label {
  display: block;
  margin-bottom: .55rem;
  font-size: .78rem;
  color: var(--muted);
  letter-spacing: .05em;
}
.chat-quick-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .55rem;
}
.chat-quick-grid .quick-question {
  min-width: 0;
  min-height: 2.4rem;
  white-space: normal;
  line-height: 1.35;
  text-align: left;
  justify-content: flex-start;
  padding: .5rem .7rem;
  border-radius: 12px;
}
[data-theme="light"] .chat-quick-grid .quick-question {
  background: rgba(255,255,255,.68);
  border-color: rgba(0,0,0,.08);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.5);
}
[data-theme="light"] .chat-quick-grid .quick-question:hover {
  background: rgba(255,255,255,.92);
  border-color: rgba(10,127,196,.24);
  color: var(--accent-2);
}
.chat-input-group {
  align-items: stretch;
}
.chat-input-group .form-control {
  min-height: 2.85rem;
}
.chat-input-group .btn {
  min-width: 5rem;
}
[data-theme="light"] .chat-input-group .form-control {
  background: rgba(255,255,255,.8);
  border-color: rgba(0,0,0,.08);
}

.fortune-strip {
  display: flex; gap: .75rem; overflow-x: auto; overflow-y: hidden;
  padding-bottom: .5rem; scroll-snap-type: x mandatory; -webkit-overflow-scrolling: touch;
}
.fortune-chip {
  min-width: 130px; flex: 0 0 auto; flex-direction: column;
  align-items: flex-start; cursor: pointer; scroll-snap-align: start;
}
.fortune-chip:hover { background: var(--surface-2); border-color: var(--border-2); transform: translateY(-2px); }
.fortune-chip.active {
  border-color: var(--accent) !important;
  box-shadow: inset 0 0 0 1px rgba(72,212,255,.18),0 4px 16px rgba(72,212,255,.1) !important;
  background: rgba(72,212,255,.06) !important;
}
.fortune-chip .minor { font-size: .78rem; color: var(--muted); }

.pill-inline {
  display: inline-flex; align-items: center; padding: .45rem .85rem;
  border-radius: 999px; background: var(--surface-2);
  border: 1px solid var(--border-1); color: var(--text); font-size: .85rem;
}

.case-toolbar {
  display: flex;
  align-items: stretch;
  gap: .55rem;
  margin-bottom: .65rem;
}
.case-search {
  display: flex; align-items: center; gap: .5rem;
  background: var(--surface-1); border: 1px solid var(--border-1);
  border-radius: 10px; padding: .35rem .75rem; margin-bottom: 0;
  min-height: 2.3rem;
  transition: border-color .18s;
}
.case-search:focus-within { border-color: var(--border-3); }
.case-search i { color: var(--muted); font-size: .85rem; flex-shrink: 0; }
.case-search input {
  flex: 1; border: none; background: transparent; outline: none;
  font-size: .82rem; color: var(--text); min-width: 0;
}
.case-search input::placeholder { color: var(--muted); }

.case-list { display: grid; gap: .5rem; max-height: 440px; overflow-y: auto; padding-right: 2px; }
.case-list::-webkit-scrollbar { width: 4px; }
.case-list::-webkit-scrollbar-track { background: transparent; }
.case-list::-webkit-scrollbar-thumb { background: var(--border-2); border-radius: 4px; }

.case-item {
  border: 1px solid var(--border-1); border-radius: 14px; padding: .72rem .85rem;
  background: var(--surface-1); cursor: pointer; position: relative;
  transition: box-shadow .18s, border-color .18s, background .18s;
  display: grid; grid-template-columns: 2.4rem 1fr auto; gap: 0 .65rem; align-items: center;
}
.case-item:hover {
  border-color: var(--border-3); background: var(--surface-2);
  box-shadow: 0 4px 20px rgba(0,0,0,.12);
}
.case-item.is-active {
  border-color: rgba(72,212,255,.35); background: rgba(72,212,255,.06);
  box-shadow: 0 0 0 1px rgba(72,212,255,.15), 0 4px 16px rgba(72,212,255,.05);
}
[data-theme="light"] .case-item.is-active {
  border-color: rgba(10,127,196,.3); background: rgba(10,127,196,.05);
  box-shadow: 0 0 0 1px rgba(10,127,196,.1);
}

.case-avatar {
  width: 2.1rem; height: 2.1rem; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: .82rem; font-weight: 700; flex-shrink: 0;
  background: linear-gradient(135deg, rgba(72,212,255,.2), rgba(62,134,255,.15));
  color: var(--accent); border: 1px solid rgba(72,212,255,.2);
  align-self: start; margin-top: .1rem;
}
[data-theme="light"] .case-avatar {
  background: linear-gradient(135deg, rgba(10,127,196,.1), rgba(29,98,204,.08));
  color: var(--accent-2); border-color: rgba(10,127,196,.18);
}
.case-item.is-active .case-avatar { background: linear-gradient(135deg, rgba(72,212,255,.3), rgba(62,134,255,.22)); }

.case-body { min-width: 0; }
.case-name {
  font-size: .88rem; font-weight: 700; color: var(--text);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  line-height: 1.3;
}
.case-item.is-active .case-name { color: var(--accent); }
[data-theme="light"] .case-item.is-active .case-name { color: var(--accent-2); }
.case-pillars {
  font-size: .72rem; color: var(--muted); margin-top: .15rem;
  letter-spacing: .05em; font-family: var(--font-mono, monospace);
}
.case-footer {
  display: flex; align-items: center; gap: .35rem; margin-top: .35rem; flex-wrap: wrap;
}
.case-tag {
  font-size: .62rem; font-weight: 600; color: var(--muted);
  background: var(--surface-2); border: 1px solid var(--border-1);
  border-radius: 999px; padding: .08rem .42rem; white-space: nowrap;
}
.case-date {
  font-size: .62rem; color: var(--muted); margin-left: auto;
  white-space: nowrap;
}

.case-actions {
  display: flex; flex-direction: column; gap: .3rem;
  opacity: 0; pointer-events: none;
  transition: opacity .15s;
  align-self: center;
}
.case-item:hover .case-actions,
.case-item:focus-within .case-actions { opacity: 1; pointer-events: auto; }
.case-action-btn {
  width: 1.85rem; height: 1.85rem; border-radius: 8px;
  border: 1px solid var(--border-2); background: var(--surface-2);
  color: var(--muted); cursor: pointer; display: flex; align-items: center;
  justify-content: center; font-size: .75rem; transition: background .15s, color .15s, border-color .15s;
  padding: 0; line-height: 1;
}
.case-action-btn:hover { background: var(--surface-3, var(--surface-2)); color: var(--text); border-color: var(--border-3); }
.case-refresh-btn {
  opacity: 1;
  pointer-events: auto;
  width: 2.3rem;
  min-width: 2.3rem;
  height: auto;
  min-height: 2.3rem;
  border-radius: 10px;
  align-self: stretch;
}
.case-action-btn.delete:hover { color: #f87171; border-color: rgba(248,113,113,.35); background: rgba(248,113,113,.08); }
.case-action-btn.load:hover { color: var(--accent); border-color: rgba(72,212,255,.3); background: rgba(72,212,255,.08); }
[data-theme="light"] .case-action-btn.load:hover { color: var(--accent-2); border-color: rgba(10,127,196,.25); background: rgba(10,127,196,.06); }

/* 删除确认覆盖层 */
.case-item.confirming-delete { border-color: rgba(248,113,113,.4); }
.case-delete-confirm {
  position: absolute; inset: 0; border-radius: 14px;
  background: rgba(10,12,20,.88); backdrop-filter: blur(4px);
  display: flex; align-items: center; justify-content: center; gap: .65rem;
  animation: fadeIn .12s;
}
[data-theme="light"] .case-delete-confirm { background: rgba(240,243,250,.92); }
.case-delete-confirm span { font-size: .8rem; color: var(--text); }
.case-delete-confirm .btn { font-size: .76rem; padding: .28rem .75rem; }

/* 空状态 */
.case-empty {
  display: flex; flex-direction: column; align-items: center;
  gap: .6rem; padding: 2.5rem 1rem; color: var(--muted); text-align: center;
}
.case-empty i { font-size: 2rem; opacity: .35; }
.case-empty .title { font-size: .88rem; font-weight: 600; color: var(--text); opacity: .6; }
.case-empty .sub { font-size: .76rem; }

/* 骨架屏 */
.case-skeleton { display: grid; gap: .5rem; }
.case-skel-item {
  border: 1px solid var(--border-1); border-radius: 14px; padding: .72rem .85rem;
  background: var(--surface-1); display: flex; gap: .65rem; align-items: center;
}
.skel-circle {
  width: 2.1rem; height: 2.1rem; border-radius: 50%;
  background: var(--border-1); flex-shrink: 0;
  animation: skelPulse 1.4s ease-in-out infinite;
}
.skel-lines { flex: 1; display: flex; flex-direction: column; gap: .4rem; }
.skel-line {
  height: .65rem; border-radius: 4px; background: var(--border-1);
  animation: skelPulse 1.4s ease-in-out infinite;
}
.skel-line.short { width: 55%; }
@keyframes skelPulse { 0%,100% { opacity: .6; } 50% { opacity: 1; } }

/* ── Toast 通知 ── */
.qh-toast {
  position: fixed; bottom: 1.5rem; left: 50%; transform: translateX(-50%) translateY(0);
  z-index: 9999; background: var(--panel-solid, rgba(18,22,34,.92)); color: var(--text);
  border: 1px solid var(--border-2); border-radius: 14px;
  padding: .65rem 1.25rem; font-size: .88rem;
  box-shadow: 0 8px 28px rgba(0,0,0,.28);
  display: flex; align-items: center; gap: .6rem;
  opacity: 0; transition: opacity .3s,transform .3s; pointer-events: none; white-space: nowrap;
}
.qh-toast.show { opacity: 1; transform: translateX(-50%) translateY(-4px); }
[data-theme="light"] .qh-toast { background: rgba(255,255,255,.97); }
.qh-toast.toast-success { border-color: rgba(72,212,255,.3); }
.qh-toast.toast-error   { border-color: rgba(255,107,107,.35); }

/* ================================================================
   宫位悬停 Tooltip
   ================================================================ */
#palaceTooltip {
  position: absolute; bottom: 1rem; left: 50%; transform: translateX(-50%) translateY(0);
  display: flex; align-items: center; gap: .55rem; flex-wrap: wrap; justify-content: center;
  background: var(--panel-solid, rgba(18,22,34,.92)); border: 1px solid var(--border-2); border-radius: 14px;
  padding: .55rem 1.1rem; font-size: .82rem;
  box-shadow: 0 6px 24px rgba(0,0,0,.32);
  pointer-events: none; white-space: nowrap;
  opacity: 0;
  transition: opacity .22s, transform .22s;
  z-index: 10;
}
#palaceTooltip.show { opacity: 1; transform: translateX(-50%) translateY(0); }
[data-theme="light"] #palaceTooltip { background: rgba(255,255,255,.96); }
.ptip-idx {
  font-size: .7rem; font-weight: 700; color: var(--muted);
  background: var(--surface-2); border-radius: 50%;
  width: 1.4rem; height: 1.4rem; display: flex; align-items: center; justify-content: center;
}
.ptip-name { font-weight: 700; color: var(--text); font-size: .88rem; }
.ptip-branch { color: var(--muted); font-size: .78rem; }
.ptip-stars { color: var(--accent); font-size: .78rem; }
[data-theme="light"] #palaceTooltip { border-color: rgba(10,127,196,.18); }

/* ================================================================
   Markdown 渲染
   ================================================================ */
.analysis-box h1.md-h1,.analysis-box h2.md-h2,.analysis-box h3.md-h3,
.chat-item h1.md-h1,.chat-item h2.md-h2,.chat-item h3.md-h3 {
  font-weight: 700; color: var(--accent); margin: .9rem 0 .35rem;
  line-height: 1.35; border-bottom: 1px solid var(--border-2); padding-bottom: .3rem;
}
.analysis-box h1.md-h1,.chat-item h1.md-h1 { font-size: 1.05rem; }
.analysis-box h2.md-h2,.chat-item h2.md-h2 { font-size: .97rem; }
.analysis-box h3.md-h3,.chat-item h3.md-h3 { font-size: .9rem; color: var(--gold); border-color: var(--border-1); }
.analysis-box p,.chat-item p { margin: 0 0 .45rem; line-height: 1.85; }
.analysis-box p.md-spacer,.chat-item p.md-spacer { margin: .2rem 0; }
.analysis-box ul,.analysis-box ol,.chat-item ul,.chat-item ol { padding-left: 1.4rem; margin: .35rem 0 .55rem; }
.analysis-box li,.chat-item li { margin-bottom: .3rem; line-height: 1.75; }
.analysis-box code,.chat-item code {
  font-family: "SF Mono","Fira Code",monospace; font-size: .82em;
  background: var(--surface-3); border: 1px solid var(--border-2);
  border-radius: 5px; padding: .1em .4em; color: var(--accent);
}
.analysis-box hr,.chat-item hr { border: none; border-top: 1px solid var(--border-2); margin: .75rem 0; }
.analysis-box strong,.chat-item strong { color: var(--text); font-weight: 700; }
.analysis-box em,.chat-item em { color: var(--orange); font-style: italic; }

/* ================================================================
   四柱命盘格网
   ================================================================ */
.bazi-grid-wrap { background: var(--surface-1); border: 1px solid var(--border-1); border-radius: 18px; padding: .85rem 1rem; }
.bazi-grid-title { font-size: .8rem; color: var(--muted); letter-spacing: .08rem; margin-bottom: .75rem; font-weight: 600; }
.bazi-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: .5rem; }
.bazi-col  { display: flex; flex-direction: column; align-items: center; gap: .3rem; }
.bazi-col--day .bazi-stem,.bazi-col--day .bazi-branch { background: rgba(72,212,255,.12); border-color: rgba(72,212,255,.28); }
.bazi-row  { width: 100%; text-align: center; font-size: .88rem; padding: .35rem .15rem; border-radius: 10px; line-height: 1.3; }
.bazi-ten-god { font-size: .72rem; color: var(--accent); background: rgba(72,212,255,.08); border: 1px solid rgba(72,212,255,.14); }
.bazi-stem    { font-size: 1.3rem; font-weight: 800; background: var(--surface-2); border: 1px solid var(--border-2); letter-spacing: .05rem; color: var(--text); }
.bazi-branch  { font-size: 1.3rem; font-weight: 800; background: var(--surface-1); border: 1px solid var(--border-1); color: var(--gold); }
.bazi-hidden  { font-size: .72rem; color: var(--muted); background: var(--surface-1); border: 1px dashed var(--border-1); min-height: 1.8rem; display: flex; align-items: center; justify-content: center; gap: .3rem; }
.bazi-hidden-god { display: inline-block; }
.bazi-nayin   { font-size: .68rem; color: var(--orange); }
.bazi-col-label { font-size: .72rem; color: var(--muted); margin-top: .1rem; }

/* ================================================================
   五行分布条
   ================================================================ */
.element-bars { display: flex; flex-direction: column; gap: .65rem; padding-top: .25rem; }
.elem-bar-row { display: grid; grid-template-columns: 32px 1fr 40px; align-items: center; gap: .55rem; }
.elem-label { font-size: .82rem; font-weight: 700; display: flex; align-items: center; gap: .25rem; color: var(--text); }
.elem-tag { font-size: .62rem; background: rgba(255,203,87,.18); color: var(--gold); border: 1px solid rgba(255,203,87,.28); border-radius: 4px; padding: 0 .25rem; }
.elem-track { height: 10px; border-radius: 99px; background: var(--surface-2); overflow: hidden; }
.elem-fill  { height: 100%; border-radius: 99px; transition: width .7s cubic-bezier(.4,0,.2,1); }
.elem-pct   { font-size: .75rem; color: var(--muted); text-align: right; }

/* ================================================================
   大运时间轴
   ================================================================ */
.dayun-strip { gap: .5rem; }
.dayun-chip  { min-width: 100px; flex-direction: column; align-items: center; text-align: center; padding: .65rem .8rem; gap: .2rem; }
.dayun-age   { font-size: .68rem; color: var(--muted); }
.dayun-pillar{ display: flex; gap: .2rem; align-items: baseline; }
.dayun-stem  { font-size: 1.2rem; font-weight: 800; color: var(--text); }
.dayun-branch{ font-size: 1.2rem; font-weight: 800; color: var(--gold); }
.dayun-active{
  border-color: rgba(255,203,87,.55) !important;
  box-shadow: inset 0 0 0 1px rgba(255,203,87,.22),0 0 16px rgba(255,203,87,.12) !important;
  background: rgba(255,203,87,.06) !important;
}
.dayun-now-tag {
  font-size: .62rem; background: rgba(255,203,87,.2); color: var(--gold);
  border: 1px solid rgba(255,203,87,.32); border-radius: 99px; padding: .1rem .5rem; margin-top: .1rem;
}

/* ================================================================
   响应式
   ================================================================ */
@media (max-width: 991.98px) {
  .mingli-stage { min-height: 480px; }
  .topbar { padding-left: 1rem !important; padding-right: 1rem !important; }
}
@media (max-width: 767.98px) {
  .container-fluid { padding-left: .75rem !important; padding-right: .75rem !important; }
  .glass-card { border-radius: 20px; padding: 1rem; }
  .mingli-stage { min-height: 320px; padding: .5rem 0 1rem; }
  .canvas-wrap { width: min(100%,560px); }
  .fortune-chip { min-width: 116px; }
  .analysis-box { min-height: 240px; }
  .timeline-lite .step { grid-template-columns: 40px 1fr; gap: .7rem; }
  .timeline-lite .step > span { width: 34px; height: 34px; border-radius: 12px; }
  .theme-toggle-btn { width: 32px; height: 32px; font-size: .9rem; }
  .analysis-top-actions { width: 100%; justify-content: flex-start; }
  .analysis-top-actions .btn { flex: 1 1 auto; }
  #chatDrawer .offcanvas-body { height: calc(100vh - 57px); padding: .9rem .85rem; }
  .chat-log { padding: .85rem; border-radius: 16px; }
  .chat-quick-grid { grid-template-columns: 1fr; }
  .chat-quick-grid .quick-question { min-height: 2.25rem; font-size: .78rem; }
  .chat-input-group .btn { min-width: 4.5rem; }
}
@media (max-width: 379.98px) {
  .topbar { padding-top: .75rem !important; padding-bottom: .75rem !important; }
  .topbar h1 { font-size: .92rem; }
  .topbar .btn { justify-content: center; }
  .glass-card { padding: .85rem; }
  .mingli-stage { min-height: 280px; }
  .fortune-chip { min-width: 104px; padding: .7rem .8rem; }
  .mini-stat .value { font-size: .92rem; }
  .analysis-box { min-height: 200px; }
}

/* ── 亮色模式 Bootstrap 覆盖 ── */
[data-theme="light"] .badge-accent { background: rgba(10,127,196,.1); color: var(--accent); border-color: rgba(10,127,196,.18); }
[data-theme="light"] .text-bg-primary { background-color: var(--accent-2) !important; }
[data-theme="light"] .text-bg-dark { background-color: var(--surface-2) !important; color: var(--text) !important; }
[data-theme="light"] .table-dark { --bs-table-bg: transparent; }

/* ── 顶栏实时时钟 ────────────────────────────────────────────────── */
.topbar-vsep {
  width: 1px; height: 22px; background: var(--border-2); margin: 0 .25rem;
}
.topbar-clock {
  display: flex; align-items: center;
  padding: .3rem .65rem; border-radius: 10px;
  background: var(--surface-1); border: 1px solid var(--border-1);
  gap: .35rem; user-select: none;
}
.clock-time {
  font-size: .92rem; font-weight: 700; color: var(--text);
  font-variant-numeric: tabular-nums; letter-spacing: .04em; line-height: 1;
}
.clock-shichen-badge {
  font-size: .65rem; font-weight: 700; line-height: 1;
  background: rgba(255,203,87,.13); color: var(--gold);
  border: 1px solid rgba(255,203,87,.25); border-radius: 999px;
  padding: .15rem .5rem; white-space: nowrap;
}
.clock-date {
  font-size: .65rem; color: var(--muted); line-height: 1; text-align: right;
}
[data-theme="light"] .topbar-clock { background: rgba(0,0,0,.04); border-color: var(--border-2); }

/* ── 时辰速选网格 ─────────────────────────────────────────────────── */
.shichen-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: .45rem;
}
.shichen-btn {
  border: 1px solid var(--border-2); background: linear-gradient(180deg, var(--surface-1), rgba(255,255,255,.01));
  color: var(--muted); border-radius: 12px; padding: .55rem .2rem .5rem;
  font-size: .9rem; font-weight: 700; cursor: pointer; text-align: center;
  min-height: 3.35rem;
  transition: background .18s, color .18s, border-color .18s, transform .14s;
  line-height: 1.25;
}
.shichen-sub {
  display: block; font-size: .64rem; font-weight: 500;
  color: var(--muted); opacity: .75;
  margin-top: .18rem;
}
.shichen-btn:hover {
  background: var(--surface-2); color: var(--text);
  border-color: var(--border-3); transform: translateY(-1px);
}
.shichen-btn.active {
  background: rgba(255,203,87,.12); color: var(--gold);
  border-color: rgba(255,203,87,.3); transform: translateY(-1px);
  box-shadow: 0 6px 18px rgba(255,203,87,.1);
}
[data-theme="light"] .shichen-btn.active {
  background: rgba(10,127,196,.08); color: var(--accent-2);
  border-color: rgba(10,127,196,.25);
}

/* ── AI 解盘维度选择 ─────────────────────────────────────────────── */
.analysis-dim-tabs {
  display: flex; gap: .3rem; flex-wrap: wrap;
}
.dim-tab {
  border: 1px solid var(--border-2); background: var(--surface-1);
  color: var(--muted); border-radius: 999px; padding: .28rem .78rem;
  font-size: .76rem; font-weight: 600; cursor: pointer; white-space: nowrap;
  transition: background .18s, color .18s, border-color .18s, box-shadow .18s;
}
.dim-tab:hover { background: var(--surface-2); color: var(--text); }
.dim-tab.active {
  background: linear-gradient(135deg, rgba(72,212,255,.16), rgba(62,134,255,.12));
  color: var(--accent); border-color: rgba(72,212,255,.32);
  box-shadow: inset 0 0 0 1px rgba(72,212,255,.1), 0 2px 8px rgba(72,212,255,.08);
}
[data-theme="light"] .dim-tab.active {
  background: linear-gradient(135deg, rgba(10,127,196,.1), rgba(29,98,204,.07));
  color: var(--accent-2); border-color: rgba(10,127,196,.28);
  box-shadow: none;
}
