html,
body,
#root {
  width: 100%;
  height: 100%;
  overflow: hidden;
}

.app {
  width: 100vw !important;
  height: 100dvh !important;
  zoom: 1 !important;
  transform: none !important;
  transform-origin: initial !important;
  display: grid !important;
  grid-template-rows: 68px minmax(0, 1fr) 50px !important;
  --board-size: min(calc(100vw - 16px), calc(100dvh - 130px), 980px) !important;
  --grid-inset: 5.5% !important;
  --grid-gap: 4px !important;
}

.app > * {
  min-width: 0 !important;
}

.top-bar,
.main,
.time-controls {
  width: 100% !important;
  max-width: 100vw !important;
}

.top-bar {
  height: 68px !important;
  min-height: 68px !important;
  padding: 0 14px !important;
  flex-wrap: nowrap !important;
  overflow: hidden !important;
}

.title-zone { min-width: 150px !important; }
.logo { font-size: 20px !important; }
.subtitle {
  display: block !important;
  font-size: 9px !important;
  letter-spacing: 0.32em !important;
}

.info-zone {
  width: auto !important;
  min-width: 0 !important;
  height: 100% !important;
  flex-wrap: nowrap !important;
  justify-content: flex-end !important;
  overflow: hidden !important;
}

.info-block,
.info-block:first-child {
  min-width: auto !important;
  padding: 0 10px !important;
}

.info-label { font-size: 8px !important; }
.info-value { font-size: 11px !important; }
.info-value.mono,
.info-value.accent { font-size: 13px !important; }

.main {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: hidden !important;
}

.taiji-bg {
  width: min(118vw, 118vh, 1180px) !important;
  height: min(118vw, 118vh, 1180px) !important;
}

.disc-wrap {
  width: var(--board-size) !important;
  height: var(--board-size) !important;
  max-width: calc(100vw - 16px) !important;
  max-height: calc(100dvh - 130px) !important;
  margin: 0 auto !important;
  transform: none !important;
}

.grid-9 {
  inset: var(--grid-inset) !important;
  gap: var(--grid-gap) !important;
  padding: var(--grid-gap) !important;
}

.cell {
  gap: 1px !important;
  padding: clamp(17px, 1.9vmin, 30px) 4px clamp(7px, 1vmin, 15px) !important;
  overflow: hidden !important;
}

.palace-tag {
  top: 6px !important;
  left: 6px !important;
  gap: 2px !important;
}

.palace-marks {
  top: 6px !important;
  right: 6px !important;
}

.pt-name { font-size: clamp(9px, 0.82vmin, 12px) !important; }
.pt-num,
.pt-dir { font-size: clamp(7px, 0.65vmin, 9px) !important; }

.mini-mark {
  min-width: 13px !important;
  height: 13px !important;
  font-size: 7px !important;
}

.row {
  gap: 1px !important;
  line-height: 1.05 !important;
}

.chip-shen {
  font-size: clamp(8px, 0.72vmin, 11px) !important;
  padding: 0 4px !important;
  gap: 1px !important;
}

.chip-shen .chip-tag,
.chip-gan-earth .chip-tag { font-size: 7px !important; }

.chip-gan-sky { font-size: clamp(11px, 1.05vmin, 16px) !important; }
.chip-gan-hidden {
  font-size: clamp(8px, 0.78vmin, 11px) !important;
  gap: 1px !important;
}

.star {
  font-size: clamp(11px, 1.16vmin, 18px) !important;
  gap: 1px !important;
  line-height: 1.08 !important;
  flex-wrap: wrap !important;
  justify-content: center !important;
  max-width: 100% !important;
}

.door {
  font-size: clamp(11px, 1.08vmin, 16px) !important;
  line-height: 1.08 !important;
}

.chip-gan-earth {
  font-size: clamp(8px, 0.78vmin, 11px) !important;
  padding: 0 4px !important;
  gap: 1px !important;
}

.chip-gan-earth-hidden { padding-inline: 3px !important; }
.badge {
  font-size: 6px !important;
  padding: 0 2px !important;
}

.palace-wx { font-size: clamp(26px, 3.5vmin, 46px) !important; }

.center-cell {
  gap: 2px !important;
  padding: clamp(12px, 1.6vmin, 22px) 4px !important;
}

.c-jieqi,
.c-label { font-size: clamp(7px, 0.7vmin, 9px) !important; }
.c-yindun { font-size: clamp(9px, 0.9vmin, 12px) !important; }
.c-num {
  font-size: clamp(25px, 3.1vmin, 44px) !important;
  margin: 0 !important;
}
.c-divider { margin: 3px 0 !important; }
.c-meta { gap: 3px !important; }
.c-meta-label { font-size: 7px !important; }
.c-meta-val { font-size: clamp(9px, 0.9vmin, 12px) !important; }

.time-controls {
  min-height: 50px !important;
  padding: 6px 8px !important;
  gap: 5px !important;
  flex-wrap: wrap !important;
  overflow: hidden !important;
}

.tc-btn {
  min-height: 28px !important;
  padding: 4px 8px !important;
  font-size: 10px !important;
}

/* 字距微调：整体再疏一点，坤二宫长文字保持可读 */
.palace-cell .star-name,
.palace-cell .door-name,
.palace-cell .chip-text,
.palace-cell .chip-gan-sky {
  letter-spacing: 0.085em !important;
}

.palace-cell .chip-tag,
.palace-cell .pt-name,
.palace-cell .pt-num,
.palace-cell .pt-dir {
  letter-spacing: 0.12em !important;
}

.palace-cell .star,
.palace-cell .door {
  gap: 4px !important;
}

.chip-gan-hidden {
  gap: 3px !important;
}

.badge {
  margin-left: 3px !important;
}

/* 背景只留太极图，去掉额外圆圈和外层光环 */
.disc-bg,
.disc-wrap::before,
.disc-wrap::after {
  display: none !important;
}

.taiji-bg {
  opacity: 0.56 !important;
  mix-blend-mode: screen !important;
}

/* 上下横栏透明化 */
.top-bar,
.time-controls {
  background: transparent !important;
  border-color: transparent !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  box-shadow: none !important;
}

.legend {
  bottom: 58px !important;
}

.qimen-home-link {
  position: fixed;
  top: 84px;
  right: 18px;
  z-index: 99999;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 38px;
  padding: 0 13px;
  border: 1px solid rgba(201, 176, 131, 0.42);
  border-radius: 999px;
  background: rgba(10, 9, 8, 0.78);
  color: #e8e0d0;
  text-decoration: none;
  font-size: 13px;
  line-height: 1;
  letter-spacing: 0.04em;
  box-shadow: 0 12px 30px rgba(0, 0, 0, 0.25);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

.qimen-home-link:hover {
  color: #c9b083;
  border-color: rgba(201, 176, 131, 0.72);
}

@media (max-width: 640px) {
  .qimen-home-link {
    top: 72px;
    right: 12px;
    min-height: 34px;
    padding: 0 10px;
    font-size: 12px;
  }

  .time-controls {
    justify-content: flex-start !important;
    flex-wrap: nowrap !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    -webkit-overflow-scrolling: touch;
  }

  .legend {
    display: none !important;
  }
}
