/* ════════════════════════════════════════════════════════════
   HXOVA 商業邏輯重構 · 詳細版 v3 · 共用樣式
   每個 partial 引用此檔；修改一處全部同步
   ════════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=DM+Mono:wght@400;500&family=Noto+Sans+TC:wght@300;400;500;600;700&family=Noto+Serif+TC:wght@400;500;600;700;900&display=swap');

:root{
  --ink:#0C2218;
  --ink-2:#1E342A;
  --ink-3:#3A4B43;
  --ink-4:#6F7F77;
  --paper:#FAF7F0;
  --paper-2:#F0EADC;
  --paper-3:#E5DECC;
  --line:rgba(12,34,24,0.20);
  --line-soft:rgba(12,34,24,0.10);
  --line-strong:rgba(12,34,24,0.40);
  --teal:#00B87A;
  --teal-2:#009E68;
  --teal-3:#2BC882;
  --teal-pale:rgba(0,184,122,0.10);
  --warn:#A35219;
  --warn-pale:rgba(163,82,25,0.10);
  --sans:'Noto Sans TC',sans-serif;
  --serif:'Noto Serif TC',serif;
  --mono:'DM Mono',monospace;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{width:100%;height:100%;overflow:hidden}
body{
  font-family:var(--sans);background:var(--paper);color:var(--ink);
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
  font-weight:400;
}
button{font-family:inherit;cursor:pointer}

.deck{position:relative;width:100vw;height:100vh}

.slide{
  position:absolute;inset:0;opacity:0;visibility:hidden;
  background:var(--paper);color:var(--ink);
  padding:4.5vh 5.5vw 5vh;
  display:flex;flex-direction:column;
  transition:opacity .3s ease,visibility .3s;
  overflow:hidden;
}
.slide.active{opacity:1;visibility:visible}

/* standalone 預覽（單個 partial）：強制顯示第一個 slide */
.deck.standalone .slide{opacity:1;visibility:visible;position:relative;inset:auto}

/* ── HEADER ──────────────────────────────────────────── */
.sd-meta{
  display:flex;justify-content:space-between;align-items:center;
  font-family:var(--mono);font-size:12.5px;font-weight:500;
  letter-spacing:0.14em;text-transform:uppercase;
  color:var(--ink-3);margin-bottom:18px;
}
.sd-meta .meta-l{display:flex;align-items:center;gap:12px}
.sd-meta .meta-l::before{content:'';width:28px;height:1.5px;background:var(--ink-3)}

.sd-title{
  font-family:var(--serif);
  font-size:clamp(40px,4.4vw,62px);
  font-weight:700;line-height:1.12;letter-spacing:-0.01em;
  color:var(--ink);
}
.sd-title .title-aux{
  font-family:var(--sans);font-weight:400;font-size:0.4em;
  color:var(--ink-3);margin-left:20px;letter-spacing:0;
  vertical-align:0.22em;
}
.sd-title-cont{
  font-family:var(--serif);
  font-size:clamp(28px,3vw,42px);
  font-weight:600;line-height:1.15;letter-spacing:-0.01em;
  color:var(--ink);
}
.sd-title-cont .cont-mark{
  font-family:var(--serif);font-weight:400;color:var(--teal-2);
  letter-spacing:0;margin-left:6px;
}
.sd-sub{
  font-family:var(--serif);
  font-size:clamp(18px,1.45vw,24px);
  font-weight:500;line-height:1.5;
  color:var(--ink-2);margin-top:8px;
}
.sd-sub-cont{
  font-family:var(--sans);
  font-size:clamp(15px,1.1vw,18px);
  font-weight:400;line-height:1.55;
  color:var(--ink-3);margin-top:6px;
  letter-spacing:0.02em;
}
.sd-sub-cont b{color:var(--ink-2);font-weight:500;font-family:var(--serif)}

/* ── LEAD BLOCK ──────────────────────────────────────── */
.sd-lead{
  background:var(--ink);
  color:var(--paper);
  padding:22px 28px;
  margin-top:22px;
  border-left:5px solid var(--teal);
  display:flex;align-items:flex-start;gap:22px;
}
.sd-lead-icon{
  font-family:var(--mono);font-size:12.5px;font-weight:600;letter-spacing:0.16em;
  text-transform:uppercase;color:var(--teal-3);
  white-space:nowrap;padding:3px 20px 0 0;
  border-right:1px solid rgba(255,255,255,0.22);
}
.sd-lead-text{
  font-family:var(--serif);
  font-size:clamp(17px,1.25vw,20px);
  line-height:1.7;font-weight:400;color:var(--paper);
}
.sd-lead-text strong{font-weight:700;color:var(--teal-3);font-family:var(--serif)}
.sd-lead-text em{font-style:normal;font-family:var(--serif);font-weight:600;color:var(--teal-3)}

/* ── DETAIL ZONE ─────────────────────────────────────── */
.sd-detail{
  flex:1;margin-top:20px;
  display:flex;flex-direction:column;
  min-height:0;gap:0;
}
.sd-detail-head{
  font-family:var(--mono);font-size:12.5px;font-weight:600;
  letter-spacing:0.14em;text-transform:uppercase;color:var(--ink-3);
  display:flex;align-items:center;gap:12px;margin-bottom:14px;
  flex-shrink:0;
}
.sd-detail-head::before,.sd-detail-head::after{
  content:'';flex:0 0 14px;height:1.5px;background:var(--ink-3);
}
.sd-detail-head::after{flex:1}

/* 2 欄並排 */
.sd-grid-2col{
  display:grid;grid-template-columns:1fr 1fr;gap:0;
  border-top:1.5px solid var(--ink);
  border-bottom:1.5px solid var(--line);
  flex-shrink:0;
}
.sd-grid-2col .sd-block{border-right:1px solid var(--line)}
.sd-grid-2col .sd-block:last-child{border-right:none}

/* 全寬區塊 */
.sd-block-fullrow{
  border-top:1.5px solid var(--ink);
  border-bottom:1px solid var(--line);
  flex-shrink:0;
}
.sd-block-fullrow.last{border-bottom:none}
.sd-block-fullrow.subtle{
  border-top:1px solid var(--line);
  background:var(--paper-2);
}
.sd-block-fullrow.takeaway{
  border-top:1.5px solid var(--ink);
  background:var(--paper);
}

/* Block 共通 */
.sd-block{
  padding:16px 24px;
  display:flex;flex-direction:column;gap:8px;
}

.sd-block-tag{
  font-family:var(--mono);font-size:12px;font-weight:600;
  letter-spacing:0.18em;text-transform:uppercase;color:var(--teal-2);
  display:flex;align-items:baseline;gap:10px;flex-wrap:wrap;
}
.sd-block-tag .tag-num{
  font-family:var(--serif);font-weight:700;
  font-size:22px;line-height:1;
  color:var(--ink);letter-spacing:-0.01em;
}
.sd-block-h{
  font-family:var(--serif);
  font-size:clamp(18px,1.3vw,22px);
  font-weight:600;line-height:1.35;
  color:var(--ink);letter-spacing:-0.005em;
}
.sd-block-body{
  font-family:var(--sans);
  font-size:clamp(15px,1.05vw,16.5px);
  line-height:1.75;font-weight:400;
  color:var(--ink);
  margin-top:2px;
}
.sd-block-body p{margin:0}
.sd-block-body p + p{margin-top:8px}
.sd-block-body strong{font-weight:600;color:var(--ink);font-family:var(--serif)}
.sd-block-body em{font-style:normal;font-family:var(--serif);font-weight:600;color:var(--teal-2)}

.sd-block-body ul{list-style:none;display:flex;flex-direction:column;gap:5px;margin-top:6px}
.sd-block-body li{padding-left:18px;position:relative;line-height:1.7}
.sd-block-body li::before{
  content:'';position:absolute;left:0;top:13px;
  width:9px;height:1.5px;background:var(--ink-3);
}

.sd-block-body .estimate{
  color:var(--warn);font-family:var(--mono);font-size:12px;
  font-weight:600;padding:1px 6px;
  background:var(--warn-pale);border-radius:2px;letter-spacing:0.04em;
}

/* Inline mini table */
.mini-tbl{width:100%;border-collapse:collapse;margin-top:6px;font-size:15px}
.mini-tbl td{padding:7px 0;border-bottom:1px dashed var(--line);font-family:var(--sans);line-height:1.5}
.mini-tbl tr:last-child td{border-bottom:none}
.mini-tbl td:first-child{color:var(--ink);padding-right:14px;font-weight:400;font-size:15px}
.mini-tbl td:last-child{
  text-align:right;font-family:var(--mono);font-weight:600;
  color:var(--ink);white-space:nowrap;font-size:14.5px;letter-spacing:0.02em;
}
.mini-tbl td.tbl-tot{font-weight:700;border-top:2px solid var(--ink);padding-top:9px;color:var(--ink);font-size:15px;font-family:var(--serif)}
.mini-tbl td.tbl-tot:last-child{font-family:var(--mono)}

/* Stat columns — for 數字真相 type pages */
.col-4{display:grid;grid-template-columns:repeat(4,1fr);gap:32px}
.col-3{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.stat-num{
  font-family:var(--serif);
  font-size:clamp(48px,5.5vw,84px);
  font-weight:700;line-height:0.95;letter-spacing:-0.03em;
  color:var(--ink);
}
.stat-num .frac{font-size:0.65em;font-weight:600}
.stat-num .plus{font-size:0.5em;font-weight:500;color:var(--ink-3);vertical-align:0.25em;margin-left:2px}
.stat-l{
  font-family:var(--mono);font-size:12px;font-weight:600;
  text-transform:uppercase;letter-spacing:0.14em;color:var(--ink-3);
  margin-top:10px;
}
.stat-sub{
  font-family:var(--sans);font-size:13.5px;font-weight:400;
  color:var(--ink-3);margin-top:6px;line-height:1.55;
}

/* Lead quote */
.lead-quote{
  font-family:var(--serif);
  font-size:clamp(22px,1.9vw,30px);
  line-height:1.45;font-weight:600;
  color:var(--ink);letter-spacing:-0.01em;
}
.lead-quote strong{color:var(--teal-2);font-weight:700}

/* Ratio bar */
.ratio-bar{
  width:100%;height:16px;background:var(--paper-3);
  margin:12px 0 10px;display:flex;overflow:hidden;border-radius:1px;
}
.ratio-bar .r-on{background:var(--teal-2)}
.ratio-bar .r-off{background:var(--ink-2)}
.ratio-labels{display:flex;justify-content:space-between;font-family:var(--mono);font-size:13px;letter-spacing:0.04em;color:var(--ink-2)}
.ratio-labels b{font-weight:700;color:var(--ink);font-family:var(--serif);font-size:14.5px}

/* 啟發點 — 3 欄並排 */
.insight-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
  margin-top:10px;counter-reset:insightnum;
}
.insight-grid .ins-col{
  display:flex;flex-direction:column;gap:8px;
  border-left:2px solid var(--teal-2);padding-left:14px;
}
.insight-grid .ins-col::before{
  counter-increment:insightnum;content:counter(insightnum,decimal-leading-zero);
  font-family:var(--serif);font-weight:700;font-size:22px;color:var(--teal-2);
  line-height:1;letter-spacing:-0.01em;
}
.insight-grid .ins-h{
  font-family:var(--serif);font-size:16px;font-weight:600;color:var(--ink);
  line-height:1.4;letter-spacing:-0.005em;
}
.insight-grid .ins-body{
  font-family:var(--sans);font-size:14px;font-weight:400;color:var(--ink-2);
  line-height:1.6;
}

/* 05 待補充 grid */
.todo-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:5px 32px;margin-top:6px;
}
.todo-grid li{font-size:14.5px;line-height:1.65}

.todo-action{
  margin-top:12px;padding:11px 16px;
  background:var(--paper);border-left:3px solid var(--warn);
  display:flex;gap:14px;align-items:flex-start;
  font-family:var(--sans);font-size:14px;line-height:1.6;color:var(--ink);
}
.todo-action-label{
  font-family:var(--mono);font-size:11.5px;font-weight:700;letter-spacing:0.14em;
  text-transform:uppercase;color:var(--warn);white-space:nowrap;
  padding-top:2px;
}
.todo-action b{font-weight:700;font-family:var(--serif)}
.todo-action .path{
  font-family:var(--mono);font-size:12.5px;color:var(--ink);
  background:rgba(12,34,24,0.07);padding:1px 5px;border-radius:2px;
  letter-spacing:0.02em;font-weight:500;
}

/* TOC list (大綱頁) */
.toc-list{
  flex:1;display:flex;flex-direction:column;gap:0;
  border-top:2px solid var(--ink);margin-top:14px;min-height:0;
}
.toc-row{
  display:grid;
  grid-template-columns:60px 220px 1fr 100px;
  gap:22px;align-items:center;
  padding:14px 0;
  border-bottom:1px solid var(--line);
}
.toc-row.empha{background:var(--teal-pale)}
.toc-row .toc-num{
  font-family:var(--serif);font-size:30px;font-weight:700;
  color:var(--ink-3);text-align:center;line-height:1;letter-spacing:-0.02em;
}
.toc-row.empha .toc-num{color:var(--teal-2)}
.toc-row .toc-name{font-family:var(--serif);font-size:18px;font-weight:600;color:var(--ink);letter-spacing:-0.005em;line-height:1.3}
.toc-row .toc-name span{display:block;font-family:var(--mono);font-size:11px;letter-spacing:0.14em;color:var(--ink-3);margin-top:4px;font-weight:500;text-transform:uppercase}
.toc-row .toc-purpose{font-family:var(--sans);font-size:14.5px;line-height:1.6;font-weight:400;color:var(--ink)}
.toc-row .toc-pages{font-family:var(--mono);font-size:12.5px;font-weight:500;color:var(--ink-2);text-align:right;letter-spacing:0.04em}

.reading-guide{
  margin-top:16px;padding:14px 20px;
  background:var(--paper-2);
  border-left:4px solid var(--ink);
  display:flex;align-items:center;gap:22px;
  font-family:var(--sans);font-size:14px;line-height:1.65;color:var(--ink);
  flex-shrink:0;
}
.reading-guide .rg-label{
  font-family:var(--mono);font-size:12px;font-weight:600;
  letter-spacing:0.16em;text-transform:uppercase;color:var(--ink-2);
  white-space:nowrap;padding-right:20px;
  border-right:1.5px solid var(--line-strong);
}
.reading-guide b{font-weight:700;color:var(--ink);font-family:var(--serif)}

/* FOOTER */
.slide-footer{
  position:absolute;bottom:1.5vh;left:5.5vw;right:5.5vw;
  display:flex;justify-content:space-between;align-items:center;
  font-family:var(--mono);font-size:11px;font-weight:500;
  letter-spacing:0.16em;text-transform:uppercase;
  color:var(--ink-3);padding-top:10px;border-top:1px solid var(--line);
}
/* standalone preview 模式 footer 也要顯示 */
.deck.standalone .slide-footer{position:absolute}

/* NAV (合併 deck.html 用) */
.deck-nav{
  position:fixed;bottom:14px;left:50%;transform:translateX(-50%);
  display:flex;gap:6px;align-items:center;
  background:rgba(12,34,24,0.95);backdrop-filter:blur(10px);
  padding:6px 11px;border-radius:100px;
  font-family:var(--mono);font-size:11.5px;color:var(--paper);
  z-index:1000;letter-spacing:0.08em;
}
.deck-nav button{
  background:transparent;border:none;color:var(--paper);
  padding:5px 10px;border-radius:100px;font-size:15px;line-height:1;
}
.deck-nav button:hover{background:rgba(255,255,255,0.12);color:var(--teal-3)}
.deck-nav .indicator{padding:0 9px;color:rgba(255,255,255,0.75);font-weight:500}
.deck-nav .indicator b{color:var(--paper);font-weight:600}

/* Draft badge */
.draft-badge{
  position:fixed;top:14px;right:18px;
  font-family:var(--mono);font-size:11px;font-weight:700;letter-spacing:0.18em;
  text-transform:uppercase;color:var(--warn);
  border:1.5px solid var(--warn);padding:4px 11px;border-radius:2px;
  z-index:998;background:var(--paper);
}

/* Standalone preview hint */
.preview-hint{
  position:fixed;top:14px;left:18px;
  font-family:var(--mono);font-size:11px;font-weight:600;letter-spacing:0.14em;
  text-transform:uppercase;color:var(--ink-3);
  border:1.5px solid var(--ink-3);padding:4px 11px;border-radius:2px;
  z-index:998;background:var(--paper);
}

@media (max-width: 1200px){
  .toc-row{grid-template-columns:44px 160px 1fr 76px;gap:14px}
  .sd-grid-2col{grid-template-columns:1fr}
  .sd-grid-2col .sd-block{border-right:none;border-bottom:1px solid var(--line)}
  .sd-grid-2col .sd-block:last-child{border-bottom:none}
  .insight-grid{grid-template-columns:1fr}
  .todo-grid{grid-template-columns:1fr}
}


/* ════════════════════════════════════════════════════════════
   本頁專用樣式（從個別 partial 抽出，供 deck.html 合併版共用）
   ════════════════════════════════════════════════════════════ */

/* === 從 04_synthesis.html 抽出 === */
/* 本頁專用 — 6 mode cards */
.mode-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:8px}
.mode-card{
  border:1.5px solid var(--line);
  padding:14px 16px;
  display:flex;flex-direction:column;gap:6px;
  background:var(--paper);
}
.mode-card.feasible-high{border-color:var(--teal-2);border-width:2px}
.mode-card.feasible-low{opacity:0.85}
.mc-head{
  display:flex;justify-content:space-between;align-items:baseline;gap:8px;
  border-bottom:1px solid var(--line);padding-bottom:8px;margin-bottom:4px;
}
.mc-num{
  font-family:var(--serif);font-size:22px;font-weight:700;
  color:var(--ink);line-height:1;letter-spacing:-0.02em;
}
.mc-rep{
  font-family:var(--mono);font-size:10.5px;font-weight:500;
  letter-spacing:0.12em;text-transform:uppercase;color:var(--ink-3);
  text-align:right;line-height:1.3;
}
.mc-name{
  font-family:var(--serif);font-size:17px;font-weight:600;
  line-height:1.3;color:var(--ink);letter-spacing:-0.005em;
}
.mc-row{
  display:grid;grid-template-columns:42px 1fr;gap:8px;
  font-family:var(--sans);font-size:13px;line-height:1.55;color:var(--ink-2);
}
.mc-row .mc-label{
  font-family:var(--mono);font-size:10px;font-weight:600;
  letter-spacing:0.1em;text-transform:uppercase;color:var(--ink-3);
  padding-top:1px;
}
.mc-row .mc-val strong{font-weight:600;color:var(--ink);font-family:var(--serif)}
.mc-foot{
  display:flex;justify-content:space-between;align-items:center;
  padding-top:8px;margin-top:4px;border-top:1px dashed var(--line);
}
.mc-foot .mc-online{
  font-family:var(--mono);font-size:11px;font-weight:600;letter-spacing:0.08em;
  color:var(--ink-3);
}
.mc-foot .mc-fit{
  font-family:var(--mono);font-size:11px;font-weight:700;letter-spacing:0.1em;
  text-transform:uppercase;padding:2px 8px;border-radius:2px;
}
.mc-fit.high{background:var(--teal-pale);color:var(--teal-2)}
.mc-fit.mid-high{background:var(--teal-pale);color:var(--teal-2)}
.mc-fit.mid{background:var(--paper-2);color:var(--ink-3)}
.mc-fit.low{background:var(--warn-pale);color:var(--warn)}

@media (max-width: 1200px){
  .mode-grid{grid-template-columns:1fr}
}

/* === 從 05_combinations.html 抽出 === */
/* 本頁專用 — 三組組合方案 cards */
.combo-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:14px;
  margin-top:10px;flex-shrink:0;
}
.combo-card{
  border:1.5px solid var(--line);
  padding:16px 18px 14px;
  display:flex;flex-direction:column;gap:10px;
  background:var(--paper);
}
.combo-card.recommended{
  border:2.5px solid var(--teal-2);
  background:var(--paper);
}
.combo-head{
  display:flex;justify-content:space-between;align-items:baseline;gap:8px;
  border-bottom:1.5px solid var(--ink);padding-bottom:10px;
}
.combo-letter{
  font-family:var(--serif);font-size:36px;font-weight:700;
  color:var(--ink);line-height:1;letter-spacing:-0.02em;
}
.combo-card.recommended .combo-letter{color:var(--teal-2)}
.combo-label{
  text-align:right;font-family:var(--mono);font-size:11px;
  font-weight:600;letter-spacing:0.12em;text-transform:uppercase;color:var(--ink-3);
}
.combo-label .combo-badge{
  display:inline-block;margin-top:4px;
  background:var(--teal-pale);color:var(--teal-2);
  padding:2px 8px;border-radius:2px;font-weight:700;letter-spacing:0.14em;
}
.combo-label .combo-badge.warn{background:var(--warn-pale);color:var(--warn)}
.combo-name{
  font-family:var(--serif);font-size:18px;font-weight:600;
  color:var(--ink);line-height:1.35;letter-spacing:-0.005em;
}
.combo-tag{
  font-family:var(--sans);font-size:13.5px;color:var(--ink-2);line-height:1.6;
}
.combo-bench-list{
  display:flex;flex-direction:column;gap:6px;
  padding-top:8px;border-top:1px solid var(--line);
}
.combo-bench-label{
  font-family:var(--mono);font-size:10.5px;font-weight:600;
  letter-spacing:0.14em;text-transform:uppercase;color:var(--ink-3);
  margin-bottom:2px;
}
.combo-bench-row{
  display:grid;grid-template-columns:1fr auto;gap:8px;
  font-family:var(--sans);font-size:13px;line-height:1.5;color:var(--ink-2);
  padding:3px 0;
}
.combo-bench-row .cb-block{font-weight:400}
.combo-bench-row .cb-block strong{font-weight:600;color:var(--ink);font-family:var(--serif)}
.combo-bench-row .cb-arrow{
  font-family:var(--mono);font-size:11px;color:var(--ink-4);padding:0 4px;
}
.combo-bench-row .cb-ref{
  font-family:var(--serif);font-size:13px;font-weight:600;
  color:var(--teal-2);text-align:right;white-space:nowrap;
}
.combo-bench-row .cb-ref.dim{color:var(--ink-3)}
.combo-foot{
  margin-top:auto;padding-top:10px;border-top:1px dashed var(--line);
  display:grid;grid-template-columns:repeat(3,1fr);gap:6px;
}
.combo-foot .cf-cell{display:flex;flex-direction:column;gap:2px}
.combo-foot .cf-l{
  font-family:var(--mono);font-size:9.5px;font-weight:600;
  letter-spacing:0.1em;text-transform:uppercase;color:var(--ink-4);
}
.combo-foot .cf-v{
  font-family:var(--serif);font-size:14px;font-weight:600;
  color:var(--ink);letter-spacing:-0.01em;
}
.combo-foot .cf-v.green{color:var(--teal-2)}
.combo-foot .cf-v.warn{color:var(--warn)}

@media (max-width: 1200px){
  .combo-grid{grid-template-columns:1fr}
}
