/* 配方製作求解器 — 工具樣式。token 來自 portal CDN（tokens.css / header.css）。 */
:root { --accent: var(--color-accent-cyan); }

/* 圖示一律不可拖曳：<img> 預設可拖曳，點技能時微滑會觸發瀏覽器原生拖曳殘影（半透明圖示浮在游標旁，曾被誤判為版面 bug）。 */
.codex-container img { -webkit-user-drag: none; user-select: none; }
.skill, .mseq-item { user-select: none; }

body {
  font-family: var(--font-sans, "Microsoft JhengHei", "Noto Sans TC", system-ui, sans-serif);
  background:
    var(--pattern-overlay),
    var(--pattern-scanline),
    var(--gradient-body, linear-gradient(135deg, #050a10, #0f151e, #1f2c3e));
  color: var(--color-text);
  min-height: 100vh;
}

/* 鐵則：codex-tablet 容器必須有 padding ≥16px（否則 .codex-hud 角標壓內文 / 字擠邊框） */
.panel { padding: var(--space-4, 16px); margin-bottom: var(--space-4, 16px); }
.panel > .codex-h2 { margin-top: 0; }

/* ---- 分頁 ---- */
.tabs { display: flex; gap: var(--space-2, 8px); margin-bottom: var(--space-4, 16px); border-bottom: 1px solid var(--color-border); }
.tab { padding: var(--space-2, 8px) var(--space-4, 16px); background: transparent; border: 1px solid transparent; border-bottom: none;
  color: var(--color-text); border-radius: var(--radius-sm, 6px) var(--radius-sm, 6px) 0 0; cursor: pointer;
  font-size: var(--fs-body); font-weight: var(--fw-semibold, 600); }
.tab:hover { background: var(--color-surface-hover); }
.tab.is-active { color: var(--accent); border-color: var(--color-border); border-bottom: 2px solid var(--accent); background: var(--color-surface); }

.run-hint { padding: var(--space-3, 12px); margin-bottom: var(--space-4, 16px); background: var(--color-surface);
  border: 1px dashed var(--accent); border-radius: var(--radius-md, 8px); }

/* ---- 選配方 ---- */
.pick-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: var(--space-3, 12px); }
.pick-head .codex-h2 { margin: 0; }
.job-chips { display: flex; flex-wrap: wrap; gap: var(--space-1, 4px); margin-bottom: var(--space-3, 12px); }
.job-chip { display: inline-flex; align-items: center; gap: var(--space-1, 4px);
  padding: var(--space-1, 4px) var(--space-3, 12px); background: var(--color-surface); border: 1px solid var(--color-border);
  border-radius: var(--radius-sm, 6px); color: var(--color-text); cursor: pointer; font-size: var(--fs-small); }
.job-chip:hover { border-color: var(--accent); }
.job-chip img { width: 18px; height: 18px; }
.job-chip.is-active { background: var(--accent); border-color: var(--accent); color: var(--color-bg); font-weight: var(--fw-semibold, 600); }
.filter-row { display: flex; flex-wrap: wrap; gap: var(--space-2, 8px); align-items: center; }
.filter-row .codex-input, .filter-row .codex-select { width: auto; }
.filter-row .grow { flex: 1; min-width: 150px; }
.filter-row .codex-select { flex: 0 0 auto; min-width: 130px; }
.filter-row .rlv-in { flex: 0 0 130px; width: 130px; }
.recipe-count { margin: var(--space-2, 8px) 0; }
.recipe-table { max-height: 320px; overflow-y: auto; border: 1px solid var(--color-border); border-radius: var(--radius-sm, 6px); }
.rt { width: 100%; border-collapse: collapse; font-size: var(--fs-small); }
.rt thead th { position: sticky; top: 0; background: var(--color-surface); color: var(--accent); text-align: left;
  padding: var(--space-2, 8px); border-bottom: 1px solid var(--color-border); font-weight: var(--fw-semibold, 600); }
.rt td { padding: var(--space-1, 4px) var(--space-2, 8px); border-bottom: 1px solid var(--color-border); }
/* 職業/Lv/配方等級 縮到內容寬，名稱吸收剩餘 → 不被拉很長 */
.rt th:not(:first-child), .rt td:not(.rt-name) { white-space: nowrap; width: 1%; }
.rt td:nth-child(3), .rt td:nth-child(4), .rt th:nth-child(3), .rt th:nth-child(4) { text-align: right; }
.rt-row { cursor: pointer; }
.rt-row:hover { background: var(--color-surface-hover); }
.rt-row.is-sel { background: var(--color-surface-hover); outline: 1px solid var(--accent); }
.rt-name { font-weight: var(--fw-semibold, 600); display: flex; align-items: center; gap: var(--space-1, 4px); }
.rt-ico { width: 24px; height: 24px; flex: none; }
.rt-job { white-space: nowrap; }
.rt-jico { width: 18px; height: 18px; vertical-align: middle; margin-right: 2px; }
.selected-bar { font-size: var(--fs-body); }
.selected-bar b { color: var(--accent); }

/* ---- 設定/結果 兩欄 ---- */
/* 左右兩欄：設定（左）＋ 結果/巨集（右） */
.work { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); gap: var(--space-4, 16px); align-items: start; }
.work[hidden] { display: none; }  /* grid 會蓋掉 hidden 屬性，須補回 */
.work .panel { margin-bottom: 0; }
@media (max-width: 760px) { .work { grid-template-columns: 1fr; } }
.results-ph { padding: var(--space-6, 32px) var(--space-3, 12px); text-align: center; color: var(--color-text-muted); line-height: var(--lh-normal, 1.5); }

.recipe-info { display: flex; align-items: center; gap: var(--space-3, 12px); margin-bottom: var(--space-3, 12px);
  flex-wrap: wrap; }
.ri-icon { width: 40px; height: 40px; border: 1px solid var(--color-border); border-radius: var(--radius-sm, 6px); flex: none; }
.ri-main { display: flex; flex-direction: column; gap: var(--space-1, 4px); min-width: 0; }
.ri-name { font-size: var(--fs-h3); color: var(--accent); font-weight: var(--fw-bold, 700); line-height: var(--lh-tight, 1.15); }
.ri-name .codex-small { color: var(--color-warn); font-weight: var(--fw-regular, 400); }
.ri-stats { display: flex; flex-wrap: wrap; gap: var(--space-2, 8px); }
.ri-stat { background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-sm, 6px);
  padding: 2px var(--space-2, 8px); font-size: var(--fs-small); }
.ri-stat b { color: var(--accent); }
.ri-jobstat { display: inline-flex; align-items: center; gap: var(--space-1, 4px); }
.ri-jico { width: 16px; height: 16px; }
.ri-mblink { width: fit-content; color: var(--accent); text-decoration: none; }
.ri-mblink:hover { text-decoration: underline; }
.ri-gear { width: 100%; }
.gear-ok { color: var(--color-success); font-weight: var(--fw-semibold, 600); }
.gear-warn { color: var(--color-warn); font-weight: var(--fw-semibold, 600); }
.ri-gear a { color: var(--accent); }

/* ---- 原料 + HQ ---- */
.ingredients { margin-bottom: var(--space-3, 12px); }
.ing-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: var(--space-2, 8px); }
.ing-group-title { font-size: var(--fs-small); color: var(--color-text-muted); font-weight: var(--fw-semibold, 600);
  margin: var(--space-2, 8px) 0 var(--space-1, 4px); }
.ing-list { display: flex; flex-direction: column; gap: var(--space-1, 4px); margin-bottom: var(--space-2, 8px); }
.ing { display: flex; align-items: center; gap: var(--space-2, 8px); min-height: 34px; padding: 0 var(--space-2, 8px);
  background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-sm, 6px); font-size: var(--fs-small); }
.ing--hq { border-color: var(--color-gold, var(--accent)); }
.ing-ico { width: 22px; height: 22px; flex: 0 0 auto; }
.ing-name { font-weight: var(--fw-semibold, 600); flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.ing-amt { color: var(--color-text); flex: 0 0 auto; }
.ing-hqctl { margin-left: auto; display: inline-flex; align-items: center; gap: var(--space-1, 4px); white-space: nowrap; }
.ing-hq-in { width: 42px; height: 26px; padding: 2px 4px; text-align: center; }
.ing-na { margin-left: auto; color: var(--color-text-muted); }
.ing-initial { padding: var(--space-2, 8px); background: var(--color-surface); border: 1px solid var(--accent); border-radius: var(--radius-sm, 6px); }
.ing-initial b { color: var(--accent); }
.ing-initial .qline { margin: 2px 0; }

/* 求解模式 + 可使用技能 */
.solve-config { margin: var(--space-3, 12px) 0 var(--space-2, 8px); display: flex; flex-direction: column; gap: var(--space-2, 8px); }
.cfg-line { display: flex; align-items: center; gap: var(--space-2, 8px); }
.cfg-line .codex-select { width: auto; flex: 1; max-width: 240px; }
.skills { display: flex; flex-wrap: wrap; gap: 3px; padding-bottom: var(--space-2, 8px); }
.skill img { width: 28px; height: 28px; display: block; border-radius: var(--radius-xs, 4px); }
.skill--locked { opacity: .3; filter: grayscale(1); }

/* config 子分組卡 — 安靜 inset（非 codex-card 互動卡：表單分組滑過不該跳動發光） */
.cfg-card { background: var(--color-bg-deep, #03060c); border: 1px solid var(--color-border);
  border-radius: var(--radius-md, 8px); padding: var(--space-3, 12px) var(--space-4, 16px) var(--space-4, 16px);
  margin-top: var(--space-4, 16px); }
.cfg-card__title { margin: 0 0 var(--space-2, 8px); }
.cfg-card .consumable-block { border-top: none; margin-top: 0; }  /* 卡內首元素免上分隔線 */

/* 消耗品與專家 */
.consumable-block { border-top: 1px solid var(--color-border); margin: var(--space-2, 8px) 0; }
.consumable-block > summary { cursor: pointer; list-style: none; padding: var(--space-2, 8px) 0; }
.consumable-block > summary::-webkit-details-marker { display: none; }
.consumable-block > summary::before { content: '▸'; color: var(--accent); margin-right: var(--space-1, 4px); display: inline-block; transition: transform var(--transition-fast, .15s); }
.consumable-block[open] > summary::before { transform: rotate(90deg); }
.consumables { display: flex; flex-direction: column; gap: var(--space-2, 8px); padding-bottom: var(--space-2, 8px); }
.consumables .cfg-line .codex-select { width: auto; flex: 1; max-width: 220px; }
.eff-stats { color: var(--color-text); }
.eff-stats b { color: var(--accent); }

/* 模式切換 + 手動排手法 */
.mode-toggle { display: flex; gap: var(--space-1, 4px); margin: var(--space-3, 12px) 0 var(--space-2, 8px); }
.mode-btn { flex: 1; padding: var(--space-2, 8px); background: var(--color-surface); border: 1px solid var(--color-border);
  border-radius: var(--radius-sm, 6px); color: var(--color-text); cursor: pointer; font-weight: var(--fw-semibold, 600); font-size: var(--fs-small); }
.mode-btn:hover { border-color: var(--accent); }
.mode-btn.is-active { background: var(--accent); border-color: var(--accent); color: var(--color-bg); }
.manual-hint { margin-bottom: var(--space-2, 8px); }
.manual-seq { display: flex; flex-wrap: wrap; gap: 3px; min-height: 44px; padding: var(--space-2, 8px);
  background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-sm, 6px);
  margin-bottom: var(--space-2, 8px); align-items: center; }
.mseq-item { cursor: pointer; }
.mseq-item img { width: 30px; height: 30px; border-radius: var(--radius-xs, 4px); display: block; }
.mseq-item:hover { outline: 1px solid var(--color-danger); }
.manual-bar { display: flex; gap: var(--space-2, 8px); margin-bottom: var(--space-2, 8px); }
.skills--pick .skill:not(.skill--locked) { cursor: pointer; }
.skills--pick .skill:not(.skill--locked):hover { outline: 1px solid var(--accent); border-radius: var(--radius-xs, 4px); }
.sum-err { color: var(--color-warn); margin-bottom: var(--space-2, 8px); }

/* ---- 求解選項 ---- */
.solve-opts { display: flex; flex-wrap: wrap; gap: var(--space-3, 12px); margin-bottom: var(--space-2, 8px); }
.opt { display: inline-flex; align-items: center; gap: var(--space-1, 4px); cursor: pointer; }
.opt input[type=checkbox] { accent-color: var(--accent); width: 16px; height: 16px; }
.opt-num input { width: 110px; }
.target-line { margin-bottom: var(--space-3, 12px); }
.solve-row { display: flex; gap: var(--space-2, 8px); align-items: center; }
.solve-status { margin-top: var(--space-2, 8px); min-height: 1.4em; display: flex; align-items: center; gap: var(--space-2, 8px); }

/* ---- 結果 + 摺疊 ---- */
.result-summary { margin-bottom: var(--space-3, 12px); }
.sum-row { display: flex; flex-wrap: wrap; align-items: center; gap: var(--space-2, 8px); margin-bottom: var(--space-2, 8px); }
.sum-meta { margin-left: auto; }
.bar-row { display: grid; grid-template-columns: 3em 1fr auto; align-items: center; gap: var(--space-2, 8px); margin: var(--space-1, 4px) 0; }
.bar-label { font-weight: var(--fw-semibold, 600); }
.bar-num { white-space: nowrap; }

.res-block { border-top: 1px solid var(--color-border); padding: var(--space-1, 4px) 0; }
.res-block > summary { cursor: pointer; list-style: none; display: flex; align-items: baseline; gap: var(--space-2, 8px); padding: var(--space-2, 8px) 0; }
.res-block > summary::-webkit-details-marker { display: none; }
.res-block > summary::before { content: '▸'; color: var(--accent); transition: transform var(--transition-fast, .15s); display: inline-block; }
.res-block[open] > summary::before { transform: rotate(90deg); }
.res-block > summary .codex-h3 { margin: 0; }

.rotation { display: flex; flex-wrap: wrap; gap: var(--space-2, 8px); padding-bottom: var(--space-2, 8px); }
/* 圖示卡放可變長技能名：fit-content 撐到名寬、名 nowrap 不切（§圖示+文字並排鐵則#2）*/
.chip { display: flex; flex-direction: column; align-items: center; gap: 2px; width: fit-content; min-width: 52px; max-width: 120px;
  padding: var(--space-1, 4px); background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-sm, 6px); }
.chip img { width: 34px; height: 34px; flex: 0 0 auto; }
.chip-name { max-width: 100%; text-align: center; line-height: var(--lh-tight, 1.15); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

.walkthrough { overflow-x: auto; padding-bottom: var(--space-2, 8px); }
.wt-table { width: 100%; border-collapse: collapse; font-size: var(--fs-small); }
.wt-table th, .wt-table td { padding: var(--space-1, 4px) var(--space-2, 8px); text-align: right; border-bottom: 1px solid var(--color-border); }
.wt-table th:nth-child(2), .wt-table td:nth-child(2) { text-align: left; }
.wt-table th { color: var(--accent); font-weight: var(--fw-semibold, 600); }
.wt-act { display: flex; align-items: center; gap: var(--space-1, 4px); }
.act-ico { width: 20px; height: 20px; }

.macro { padding-bottom: var(--space-2, 8px); }
.macro-block { margin-bottom: var(--space-3, 12px); }
.macro-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: var(--space-1, 4px); }
.macro-text { width: 100%; resize: vertical; font-family: var(--font-mono); }

/* ---- 角色數值表 ---- */
.hint { margin-bottom: var(--space-4, 16px); }
.gearsets { overflow-x: auto; }  /* 窄螢幕表格內部橫捲，不撐破頁面 */
.gear-table { width: auto; border-collapse: collapse; }  /* 內容寬度，不再撐滿整個面板 */
.gear-table th, .gear-table td { padding: var(--space-2, 8px) var(--space-3, 12px); border-bottom: 1px solid var(--color-border); }
.gear-table thead th { color: var(--accent); text-align: right; font-weight: var(--fw-semibold, 600); }
.gear-table thead th:first-child { text-align: left; }
.gear-table tbody tr:hover { background: var(--color-surface-hover); }
.gear-table .gj { text-align: left; font-weight: var(--fw-semibold, 600); white-space: nowrap; }
.gear-table .gj-default { color: var(--accent); }
.gear-in { width: 96px; text-align: right; }  /* 數字欄固定窄寬 + 右對齊 */

.attribution { margin-top: var(--space-5, 24px); opacity: .85; }
.attribution a { color: var(--accent); }
