/* ============================================================
   常启工具箱 — 页面专属样式（依赖 tokens.css / app.css）
   复用 .tool-grid/.tool-cell 等组件，仅补充工具内部样式。
   ============================================================ */

/* —— 工具宫格（与首页一致，本页未引 home.css 故在此声明）—— */
.tool-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-3); }
@media (max-width: 560px) { .tool-grid { grid-template-columns: repeat(2, 1fr); } }
.tool-cell { display: flex; flex-direction: column; align-items: center; text-align: center; gap: 6px; padding: var(--sp-4) var(--sp-2); background: #fff; border: 1px solid var(--c-line); border-radius: var(--radius); transition: .18s; }
.tool-cell:hover { border-color: var(--c-primary); transform: translateY(-2px); box-shadow: var(--shadow-sm); }
.tool-cell .ic { width: 44px; height: 44px; border-radius: 12px; display: grid; place-items: center; font-family: var(--font-serif); font-size: 22px; color: var(--c-primary-deep); background: var(--c-primary-soft); }
.tool-cell b { font-family: var(--font-serif); font-size: 15px; color: var(--c-ink); }
.tool-cell span { font-size: var(--t-xs); color: var(--c-ink-3); line-height: 1.4; }

/* —— 星级（生肖运势，本页未引 home.css 故在此声明）—— */
.star-list { display: grid; gap: 8px; }
.star-row { display: flex; align-items: center; font-size: var(--t-sm); }
.star-row .lbl { color: var(--c-ink-2); width: 48px; flex: none; }
.star-row .stars { letter-spacing: 2px; color: var(--c-luck); font-size: 16px; }
.star-row .stars .off { color: var(--c-line); }

/* ====================== 五行穿衣 ====================== */
.wx-today { display: flex; align-items: center; gap: var(--sp-4); flex-wrap: wrap; }
.wx-self { width: 64px; height: 64px; flex: none; border-radius: var(--radius); display: grid; place-items: center; font-family: var(--font-serif); font-weight: 900; font-size: 32px; color: #fff; box-shadow: var(--shadow-sm); }
.wx-self.wx-木 { background: linear-gradient(160deg, #2E7D32, #1F8A4D); }
.wx-self.wx-火 { background: linear-gradient(160deg, #C0392B, #7B3FA0); }
.wx-self.wx-土 { background: linear-gradient(160deg, #D6A93C, #8A5A2B); }
.wx-self.wx-金 { background: linear-gradient(160deg, #C8CBD0, #9aa0a8); color: #2B2B2B; }
.wx-self.wx-水 { background: linear-gradient(160deg, #234E9C, #2B2B2B); }
.wx-self-txt { flex: 1; min-width: 200px; }
.wx-self-txt p { margin: 0; }

.wx-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-3); }
@media (max-width: 560px) { .wx-cards { grid-template-columns: 1fr; } }
.wx-card { border: 1px solid var(--c-line); border-radius: var(--radius); padding: var(--sp-4); text-align: center; background: #fff; }
.wx-card-daji { border-color: rgba(201, 154, 46, .5); background: rgba(201, 154, 46, .06); }
.wx-card-ciji { border-color: rgba(46, 125, 50, .35); background: rgba(46, 125, 50, .05); }
.wx-card-ji { border-color: rgba(192, 57, 43, .35); background: #fff; }
.wx-card-hd { display: flex; align-items: center; justify-content: center; gap: 8px; margin-bottom: 12px; }
.wx-tag { font-family: var(--font-serif); font-weight: 700; font-size: var(--t-h2); }
.wx-card-daji .wx-tag { color: var(--c-luck); }
.wx-card-ciji .wx-tag { color: var(--c-yi); }
.wx-card-ji .wx-tag { color: var(--c-ji); }
.wx-sub { font-size: var(--t-xs); color: var(--c-ink-3); }
.wx-swatches { display: flex; justify-content: center; gap: 8px; margin-bottom: 12px; }
.wx-swatches i { width: 34px; height: 34px; border-radius: 50%; display: block; border: 2px solid #fff; box-shadow: 0 0 0 1px var(--c-line), var(--shadow-sm); }
.wx-card-ft b { font-family: var(--font-serif); font-size: 16px; color: var(--c-ink); }

.wx-advice { margin-top: var(--sp-4); padding: var(--sp-4); border: 1px dashed var(--c-line); border-radius: var(--radius); background: var(--c-primary-soft); }
.wx-advice p { margin: 8px 0 0; color: var(--c-ink); font-size: var(--t-body); }

/* ====================== 生肖运势 ====================== */
.sx-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: var(--sp-2); }
@media (max-width: 560px) { .sx-grid { grid-template-columns: repeat(4, 1fr); } }
.sx-cell { border: 1px solid var(--c-line); background: #fff; border-radius: var(--radius); padding: var(--sp-3) 0; transition: .16s; }
.sx-cell:hover { border-color: var(--c-primary); transform: translateY(-2px); box-shadow: var(--shadow-sm); }
.sx-cell.sel { border-color: var(--c-primary); background: var(--c-primary-soft); }
.sx-char { font-family: var(--font-serif); font-weight: 700; font-size: 22px; color: var(--c-ink); }
.sx-cell.sel .sx-char { color: var(--c-primary-deep); }

.sx-result { display: flex; align-items: center; gap: var(--sp-5); flex-wrap: wrap; }
.sx-sym { width: 72px; height: 72px; flex: none; border-radius: var(--radius); display: grid; place-items: center; font-family: var(--font-serif); font-weight: 900; font-size: 38px; color: #fff; background: linear-gradient(160deg, var(--c-primary), var(--c-primary-deep)); box-shadow: inset 0 0 0 1.5px var(--c-gold-light); }

/* ====================== 称骨算命 ====================== */
.cg-fields { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--sp-3); margin-bottom: var(--sp-4); }
@media (max-width: 560px) { .cg-fields { grid-template-columns: 1fr; } }
.cg-field { display: grid; gap: 6px; }
.cg-field span { font-size: var(--t-sm); color: var(--c-ink-2); }
.cg-field select { font: inherit; padding: 9px 12px; border: 1px solid var(--c-line); border-radius: var(--radius); background: #fff; color: var(--c-ink); }
.cg-field select:focus { outline: 0; border-color: var(--c-primary); }
.cg-form .btn { margin-bottom: 8px; }
.cg-error { color: var(--c-ji); font-size: var(--t-sm); margin: 0 0 var(--sp-3); }

.cg-total { display: flex; align-items: center; gap: var(--sp-4); flex-wrap: wrap; padding-bottom: var(--sp-4); border-bottom: 1px dashed var(--c-line); }
.cg-weight { text-align: center; flex: none; }
.cg-weight b { display: block; font-size: var(--t-hero); line-height: 1; color: var(--c-primary); font-weight: 900; }
.cg-weight small { font-size: var(--t-xs); color: var(--c-ink-3); }
.cg-title { font-family: var(--font-serif); font-weight: 700; font-size: var(--t-h1); color: var(--c-gold); }

.cg-breakdown { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--sp-2); margin: var(--sp-4) 0; }
@media (max-width: 560px) { .cg-breakdown { grid-template-columns: repeat(2, 1fr); } }
.cg-part { text-align: center; padding: var(--sp-3) 6px; border: 1px solid var(--c-line); border-radius: var(--radius); background: #fff; }
.cg-part small { display: block; font-size: var(--t-xs); color: var(--c-ink-3); margin-bottom: 4px; }
.cg-part b { font-family: var(--font-serif); font-size: 16px; color: var(--c-ink); }

.cg-verse { margin-top: var(--sp-2); padding: var(--sp-4); border-radius: var(--radius); background: var(--c-primary-soft); border: 1px dashed rgba(192, 57, 43, .25); }
.cg-verse p { margin: 8px 0 0; font-family: var(--font-serif); font-size: 16px; line-height: 1.9; color: var(--c-ink); }

/* 生肖动物图（图库网格 + 今日运势按钮） */
.sx-item { display: flex; flex-direction: column; align-items: center; gap: 6px; }
.sx-cell { display: block; text-align: center; text-decoration: none; width: 100%; }
.sx-cell .sx-img { display: block; width: 72px; height: 78px; margin: 0 auto 2px; object-fit: contain; border-radius: 10px; background: #12182b; }
.sx-cell .sx-char { display: block; }
.sx-branch { display: block; font-size: var(--t-xs, .74rem); color: var(--c-ink-3); margin-top: 1px; }
.sx-fortune-btn { font: inherit; font-size: var(--t-xs, .74rem); cursor: pointer; padding: 4px 12px; border-radius: 999px; border: 1px solid var(--c-gold-light, #e5cf94); background: var(--c-primary-soft, #fbf3ef); color: var(--c-gold-ink, #8a6d1f); transition: .16s; }
.sx-fortune-btn:hover { border-color: var(--c-primary); color: var(--c-primary-deep); background: #fff; }
.sx-story-link { font-size: var(--t-xs, .74rem); color: var(--c-gold-ink, #8a6d1f); text-decoration: none; }
.sx-story-link:hover { text-decoration: underline; }
