/* ============================================================
   出海十二星座 — 页面专属样式
   依赖 tokens.css + app.css，仅补充星座模块所需样式。
   ============================================================ */

/* —— 列表页：四象分组卡片网格 —— */
.xz-group { margin-bottom: var(--sp-5); }
.xz-el-badge {
  display: inline-grid; place-items: center; width: 24px; height: 24px;
  border-radius: 50%; font-size: var(--t-sm); color: #fff; margin-right: 4px;
  background: linear-gradient(160deg, var(--c-primary), var(--c-primary-deep));
  font-family: var(--font-serif);
}

.xz-grid {
  display: grid; gap: var(--sp-3);
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
@media (min-width: 720px) { .xz-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); } }

.xz-card {
  display: flex; flex-direction: column; gap: 3px;
  padding: var(--sp-4); border: 1px solid var(--c-line); border-radius: var(--radius);
  background: #fff; position: relative; overflow: hidden;
  transition: transform .14s, box-shadow .18s, border-color .18s;
}
.xz-card:hover { transform: translateY(-2px); box-shadow: var(--shadow); border-color: var(--c-gold-light); }
.xz-card-el {
  position: absolute; top: 10px; right: 12px;
  font-family: var(--font-serif); font-size: 28px; color: var(--c-primary-soft);
  line-height: 1; pointer-events: none;
}
.xz-card-name { font-family: var(--font-serif); font-weight: 700; font-size: var(--t-h2); color: var(--c-ink); }
.xz-card-date { font-size: var(--t-sm); color: var(--c-primary-deep); }
.xz-card-ruling { font-size: var(--t-xs); }

/* —— 详情页：头图 —— */
.xz-hero {
  display: flex; align-items: center; gap: var(--sp-5);
  padding: var(--sp-5); position: relative; overflow: hidden;
}
.xz-hero-sym {
  flex: none; width: 80px; height: 80px; border-radius: 50%;
  display: grid; place-items: center;
  font-family: var(--font-serif); font-size: 38px; color: #fff;
  background: linear-gradient(160deg, var(--c-primary), var(--c-primary-deep));
  box-shadow: inset 0 0 0 2px var(--c-gold-light), var(--shadow);
}
.xz-hero-name { font-size: var(--t-hero); margin: 0; }
.xz-hero-date { font-size: var(--t-h2); color: var(--c-primary-deep); margin: 2px 0 10px; }
.xz-hero-tags { display: flex; flex-wrap: wrap; gap: 8px; }

/* 四象底色微调（土/风/水换守护色调，统一朱砂体系不破坏 token） */
.xz-el-bg-土 .xz-hero-sym { background: linear-gradient(160deg, #B8860B, #8a6608); }
.xz-el-bg-风 .xz-hero-sym { background: linear-gradient(160deg, #2C6E9B, #1f5273); }
.xz-el-bg-水 .xz-hero-sym { background: linear-gradient(160deg, #2E7D32, #1f5723); }

/* —— 性格 / 信息行 —— */
.xz-kv-row { display: flex; flex-wrap: wrap; gap: var(--sp-3) var(--sp-5); margin-top: var(--sp-4); padding-top: var(--sp-4); border-top: 1px dashed var(--c-line); }

/* —— 今日运势星级 —— */
.xz-fortune { display: grid; gap: var(--sp-3); grid-template-columns: 1fr; }
@media (min-width: 560px) { .xz-fortune { grid-template-columns: repeat(2, 1fr); } }
.xz-ft-item {
  display: flex; align-items: center; gap: var(--sp-3);
  padding: 10px var(--sp-4); border: 1px solid var(--c-line);
  border-radius: var(--radius); background: var(--c-paper);
}
.xz-ft-label { font-family: var(--font-serif); font-weight: 700; color: var(--c-ink); min-width: 3em; }
.xz-stars { font-size: 18px; letter-spacing: 2px; line-height: 1; }
.xz-stars .off { color: var(--c-line); }
.xz-ft-note {
  margin: var(--sp-4) 0 0; padding: var(--sp-3) var(--sp-4);
  background: var(--c-primary-soft); color: var(--c-primary-deep);
  border-radius: var(--radius); font-size: var(--t-sm); line-height: 1.7;
}

/* —— 配对 / 幸运 —— */
.info-grid { display: grid; gap: var(--sp-4); grid-template-columns: 1fr; }
@media (min-width: 560px) { .info-grid { grid-template-columns: 1.4fr 1fr; align-items: start; } }
.xz-match h4 { font-size: var(--t-sm); color: var(--c-ink-2); margin-bottom: 10px; }
.xz-lucky { display: grid; gap: var(--sp-3); align-content: start; }
.xz-lucky .kv .v b { color: var(--c-primary-deep); }

/* —— 上/下导航条 —— */
.day-nav { display: flex; gap: var(--sp-2); flex-wrap: wrap; justify-content: space-between; }
.day-nav .btn { flex: 1 1 auto; }

/* 星座卡通图（索引卡片 / 详情头图 / 联动推荐） */
.xz-card-img { display: block; width: 88px; height: 95px; margin: 0 auto 6px; object-fit: contain;
  border-radius: 12px; background: #0e1428; }
.xz-hero-img { width: 120px; height: 130px; flex: 0 0 120px; object-fit: contain; border-radius: 16px;
  background: #0e1428; box-shadow: 0 4px 16px rgba(0,0,0,.18); }
.xz-reco { display: grid; grid-template-columns: repeat(auto-fill, minmax(120px, 1fr)); gap: 12px; }
.xz-reco-card { display: flex; flex-direction: column; align-items: center; gap: 4px; text-decoration: none;
  color: var(--c-ink); padding: 10px; border: 1px solid var(--c-line, #ece7dd); border-radius: 12px; transition: box-shadow .2s, border-color .2s; }
.xz-reco-card:hover { box-shadow: var(--shadow, 0 4px 18px rgba(0,0,0,.07)); border-color: var(--c-gold-light, #d9c48a); }
.xz-reco-card img { width: 72px; height: 78px; object-fit: contain; border-radius: 10px; background: #0e1428; }
.xz-reco-card b { font-size: var(--t-base, 1rem); }
