/*
  ╔══════════════════════════════════════════════════════╗
  ║  shared/style.css  —  全站共用設計系統  v3           ║
  ║                                                      ║
  ║  v3 更新：                                           ║
  ║  ① 字體全面放大（內文 16px，說明 14px）              ║
  ║  ② 配色降飽和、收斂，減少同時出現的顏色種類          ║
  ║  ③ 新增進階學習者元件（.adv-* 系列）                 ║
  ║  ④ 統一學習流程標示元件（.flow-step）               ║
  ║  ⑤ 共用 P1–P4 心理學元件移入此檔                    ║
  ╚══════════════════════════════════════════════════════╝
*/

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

/* ─────────────────────────────────────────────
   § 1. 設計 Token
   ───────────────────────────────────────────── */
:root {
  /* 背景層次 — 全站統一 */
  --bg:       #0A0F1A;
  --surface:  #111827;
  --surface2: #182030;
  --border:   #1E2D45;

  /* 文字 — 只用兩種灰，不再多 */
  --text:     #C8D0E0;
  --text-dim: #5A6580;
  --text-mid: #8A96AE;

  /* 語意色 — 只在回饋瞬間出現 */
  --green:  #22C55E;
  --red:    #EF4444;
  --yellow: #F5C400;   /* 預測框/強調，謹慎使用 */

  /* 各單元主題色（降飽和，不再螢光）*/
  --array-color:  #38BDF8;   /* 冰藍，原 #00e5ff 降飽和 */
  --array-glow:   rgba(56,189,248,0.12);
  --array-dim:    rgba(56,189,248,0.06);

  --linked-color: #FB923C;   /* 暖橘，原 #ff6b35 降飽和 */
  --linked-glow:  rgba(251,146,60,0.12);
  --linked-dim:   rgba(251,146,60,0.06);

  --stack-color:  #A78BFA;   /* 薰衣草紫，維持 */
  --stack-glow:   rgba(167,139,250,0.12);
  --stack-dim:    rgba(167,139,250,0.06);

  --queue-color:  #34D399;   /* 薄荷綠，維持 */
  --queue-glow:   rgba(52,211,153,0.12);
  --queue-dim:    rgba(52,211,153,0.06);

  --tree-color:   #34D399;   /* tree.html 主題色統一用此 */
  --tree-glow:    rgba(52,211,153,0.12);
  --tree-dim:     rgba(52,211,153,0.06);

  /* 進階學習者專用色 */
  --adv-color:    #818CF8;   /* 靛紫，與主題色區隔 */
  --adv-glow:     rgba(129,140,248,0.10);
  --adv-border:   rgba(129,140,248,0.25);

  /* 字型 */
  --font-mono: 'JetBrains Mono', monospace;
  --font-ui:   'Noto Sans TC', sans-serif;

  /* 字體大小 — v3 統一放大 */
  --text-xs:   12px;
  --text-sm:   14px;
  --text-base: 16px;
  --text-lg:   18px;
  --text-xl:   22px;
  --text-2xl:  28px;

  /* 間距 */
  --nav-height: 56px;
  --radius-sm:  8px;
  --radius-md:  12px;
  --radius-lg:  16px;
}

/* ─────────────────────────────────────────────
   § 2. Reset & 全站基礎
   ───────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

body {
  background: var(--bg);
  color: var(--text);
  font-family: var(--font-ui);
  font-size: var(--text-base);   /* 全站基礎 16px */
  line-height: 1.8;
  min-height: 100vh;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}

/* 點陣格線背景 — 降低到 0.02 更收斂 */
body::before {
  content: '';
  position: fixed; inset: 0;
  background-image:
    linear-gradient(rgba(56,189,248,0.02) 1px, transparent 1px),
    linear-gradient(90deg, rgba(56,189,248,0.02) 1px, transparent 1px);
  background-size: 40px 40px;
  pointer-events: none;
  z-index: 0;
}

.wrapper {
  position: relative; z-index: 1;
  max-width: 1100px;
  margin: 0 auto;
  padding: 32px 20px 80px;
}

/* ─────────────────────────────────────────────
   § 3. 導覽列
   ───────────────────────────────────────────── */
.site-nav {
  position: sticky; top: 0; z-index: 100;
  height: var(--nav-height);
  background: rgba(10,15,26,0.94);
  backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--border);
  display: flex; align-items: center;
  padding: 0 24px; gap: 0;
}

.nav-logo {
  font-family: var(--font-mono);
  font-size: var(--text-sm); font-weight: 700;
  color: var(--array-color);
  text-decoration: none;
  letter-spacing: 2px;
  margin-right: 32px;
  white-space: nowrap;
}

.nav-links {
  display: flex; gap: 4px; flex: 1; flex-wrap: wrap;
}

.nav-link {
  padding: 6px 14px; border-radius: 6px;
  font-size: var(--text-sm); font-weight: 500;
  color: var(--text-dim); text-decoration: none;
  transition: all 0.15s; white-space: nowrap;
  display: flex; align-items: center; gap: 6px;
}
.nav-link:hover { color: var(--text); background: var(--surface2); }
.nav-link.active { color: var(--array-color); background: var(--surface2); }

.nav-link .nav-dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--border); flex-shrink: 0;
  transition: background 0.2s;
}
.nav-link.done .nav-dot   { background: var(--green); }
.nav-link.active .nav-dot { background: var(--array-color); }

/* ─────────────────────────────────────────────
   § 4. 頁面 Header
   ───────────────────────────────────────────── */
.page-header { text-align: center; margin-bottom: 48px; }

.page-subtitle {
  font-family: var(--font-mono);
  color: var(--text-dim);
  font-size: var(--text-xs); letter-spacing: 4px;
  text-transform: uppercase; margin-bottom: 14px;
}

.page-title {
  font-size: clamp(var(--text-xl), 5vw, 44px);
  font-weight: 700; line-height: 1.15;
}

.page-tagline {
  color: var(--text-mid);
  font-size: var(--text-sm);
  margin-top: 12px;
  line-height: 1.7;
}

/* ─────────────────────────────────────────────
   § 5. Tab 系統（全站統一，不再各頁自定）
   ───────────────────────────────────────────── */
.tabs {
  display: flex; gap: 8px;
  justify-content: center;
  margin-bottom: 36px; flex-wrap: wrap;
}

/* 通用 tab 按鈕 — 各頁面都用這個 class */
.tab {
  padding: 10px 22px; border-radius: var(--radius-sm);
  border: 1px solid var(--border);
  background: var(--surface); color: var(--text-dim);
  cursor: pointer; font-family: var(--font-ui);
  font-size: var(--text-sm); font-weight: 600;
  transition: all 0.2s; white-space: nowrap;
  display: flex; align-items: center; gap: 8px;
}
.tab:hover { border-color: var(--text-mid); color: var(--text); }

/* active 狀態由 JS 加上 data-theme 的顏色 */
.tab.active {
  font-weight: 700;
  border-color: currentColor;
  background: var(--surface2);
  font-family: var(--font-mono); letter-spacing: 1px; /*  active 狀態字體改用 Mono，增加識別度 */
}

/* 各頁 active 主題色 */
.tab.active.theme-array  { color: var(--array-color); }
.tab.active.theme-stack  { color: var(--stack-color); }
.tab.active.theme-queue  { color: var(--queue-color); }
.tab.active.theme-tree   { color: var(--tree-color); }

/* tab 數字圓圈 */
.tab-num {
  width: 22px; height: 22px; border-radius: 50%;
  background: var(--surface2); border: 1px solid var(--border);
  display: flex; align-items: center; justify-content: center;
  font-size: 11px; font-weight: 900;
  font-family: var(--font-mono); flex-shrink: 0;
  color: var(--text-dim);
  transition: all 0.2s;
}
.tab.active .tab-num {
  background: rgba(255,255,255,0.08);
  border-color: currentColor;
  color: inherit;
}

.panel { display: none; }
.panel.active { display: block; }

/* ─────────────────────────────────────────────
   § 6. 卡片元件
   ───────────────────────────────────────────── */
.card {
  background: var(--surface); border-radius: var(--radius-md);
  border: 1px solid var(--border); overflow: hidden;
  margin-bottom: 20px;
}
.card-header {
  padding: 16px 20px; border-bottom: 1px solid var(--border);
  display: flex; align-items: center; gap: 10px;
}
.card-body { padding: 22px; }
.card-title { font-size: var(--text-lg); font-weight: 700; }

/* ─────────────────────────────────────────────
   § 7. 按鈕系統 — 統一大小
   ───────────────────────────────────────────── */
.btn {
  padding: 9px 18px; border-radius: var(--radius-sm); border: none;
  cursor: pointer; font-family: var(--font-ui);
  font-size: var(--text-sm); font-weight: 600;
  transition: all 0.2s; white-space: nowrap;
  display: inline-flex; align-items: center; gap: 6px;
}
.btn:hover   { transform: translateY(-1px); filter: brightness(1.1); }
.btn:active  { transform: translateY(0); }

.btn-arr     { background: var(--array-glow);  color: var(--array-color);  border: 1px solid rgba(56,189,248,0.3); }
.btn-lnk     { background: var(--linked-glow); color: var(--linked-color); border: 1px solid rgba(251,146,60,0.3); }
.btn-stack   { background: var(--stack-glow);  color: var(--stack-color);  border: 1px solid rgba(167,139,250,0.3); }
.btn-queue   { background: var(--queue-glow);  color: var(--queue-color);  border: 1px solid rgba(52,211,153,0.3); }
.btn-tree    { background: var(--tree-glow);   color: var(--tree-color);   border: 1px solid rgba(52,211,153,0.3); }
.btn-del     { background: rgba(239,68,68,0.1); color: var(--red);         border: 1px solid rgba(239,68,68,0.3); }
.btn-neutral { background: var(--surface2);    color: var(--text);         border: 1px solid var(--border); }
.btn-adv     { background: var(--adv-glow);    color: var(--adv-color);    border: 1px solid var(--adv-border); }

/* ─────────────────────────────────────────────
   § 8. 輸入欄位
   ───────────────────────────────────────────── */
.controls {
  display: flex; gap: 8px; flex-wrap: wrap;
  margin-top: 16px; align-items: center;
}
.input-wrap {
  display: flex; align-items: center;
  background: var(--surface2); border: 1px solid var(--border);
  border-radius: var(--radius-sm); overflow: hidden;
}
.input-label {
  padding: 0 10px; font-size: var(--text-xs);
  color: var(--text-dim); white-space: nowrap;
}
.ctrl-input {
  background: none; border: none; color: var(--text);
  font-family: var(--font-mono); font-size: var(--text-sm);
  width: 60px; padding: 8px 8px 8px 0; outline: none;
}
.ctrl-input:focus { outline: none; }
.controls input[type=number] {
  width: 64px; padding: 8px 10px; border-radius: var(--radius-sm);
  border: 1px solid var(--border); background: var(--surface2);
  color: var(--text); font-family: var(--font-mono); font-size: var(--text-sm);
}
.controls input:focus { outline: none; border-color: var(--yellow); }

/* ─────────────────────────────────────────────
   § 9. Log 輸出列
   ───────────────────────────────────────────── */
.log, .log-box {
  background: var(--surface2); border-radius: var(--radius-sm);
  padding: 11px 16px; font-family: var(--font-mono); font-size: var(--text-sm);
  color: var(--text-dim); min-height: 40px; line-height: 1.6;
  margin-top: 12px; border: 1px solid var(--border);
  transition: all 0.3s;
}
.log .step { color: var(--text-dim); }
.log .warn, .log-box.warn { color: var(--yellow); border-color: rgba(245,196,0,0.3); background: rgba(245,196,0,0.05); }
.log .err,  .log-box.error { color: var(--red);    border-color: rgba(239,68,68,0.3);  background: rgba(239,68,68,0.05); }
.log-box.success { color: var(--green);  border-color: rgba(34,197,94,0.3);  background: rgba(34,197,94,0.05); }
.log-box.info    { color: var(--adv-color); border-color: var(--adv-border); background: var(--adv-glow); }

/* ─────────────────────────────────────────────
   § 10. 類比 Banner
   ───────────────────────────────────────────── */
.analogy {
  background: var(--surface2); border-radius: var(--radius-sm);
  padding: 14px 18px; margin-bottom: 20px;
  border-left: 3px solid currentColor;
  font-size: var(--text-sm); line-height: 1.8;
}
.analogy strong { display: block; font-size: var(--text-xs); letter-spacing: 1px; opacity: 0.7; margin-bottom: 6px; }
.analogy.arr   { color: var(--array-color); }
.analogy.lnk   { color: var(--linked-color); }
.analogy.stack { color: var(--stack-color); }
.analogy.queue { color: var(--queue-color); }
.analogy.tree  { color: var(--tree-color); }

/* ─────────────────────────────────────────────
   § 11. Section 標題
   ───────────────────────────────────────────── */
.section-title {
  font-size: var(--text-xs); letter-spacing: 3px; color: var(--text-dim);
  text-transform: uppercase; font-family: var(--font-mono);
  margin-bottom: 14px; margin-top: 28px;
}
.section-title:first-child { margin-top: 0; }

/* 功能區塊標號 (A/B/C/D) */
.section-badge {
  display: inline-flex; align-items: center; justify-content: center;
  width: 28px; height: 28px; border-radius: 50%;
  font-size: var(--text-sm); font-weight: 800; font-family: var(--font-mono);
  background: var(--surface2); border: 1.5px solid currentColor;
  flex-shrink: 0;
}
.section-badge.arr   { color: var(--array-color); }
.section-badge.lnk   { color: var(--linked-color); }
.section-badge.stack { color: var(--stack-color); }
.section-badge.queue { color: var(--queue-color); }
.section-badge.tree  { color: var(--tree-color); }
.section-badge.gold  { color: var(--yellow); }

.section-label {
  display: flex; align-items: center; gap: 10px;
  font-size: var(--text-base); font-weight: 700;
  margin-bottom: 12px; color: var(--text);
}

/* ─────────────────────────────────────────────
   § 12. 版面系統
   ───────────────────────────────────────────── */
.side-by-side {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 20px; margin-bottom: 24px;
}
@media (max-width: 700px) { .side-by-side { grid-template-columns: 1fr; } }

.two-col {
  display: grid; grid-template-columns: 1fr 1fr; gap: 16px;
}
@media (max-width: 680px) { .two-col { grid-template-columns: 1fr; } }

/* ─────────────────────────────────────────────
   § 13. 複雜度表格
   ───────────────────────────────────────────── */
.complexity {
  background: var(--surface); border-radius: var(--radius-md);
  border: 1px solid var(--border);
  overflow: hidden; margin-bottom: 24px;
}
.complexity table { width: 100%; border-collapse: collapse; }
.complexity th {
  padding: 13px 18px; text-align: left; font-size: var(--text-xs);
  letter-spacing: 1px; background: var(--surface2);
  border-bottom: 1px solid var(--border);
}
.complexity th.arr-h   { color: var(--array-color); }
.complexity th.lnk-h   { color: var(--linked-color); }
.complexity th.stack-h { color: var(--stack-color); }
.complexity th.queue-h { color: var(--queue-color); }
.complexity th.tree-h  { color: var(--tree-color); }
.complexity td { padding: 13px 18px; border-bottom: 1px solid var(--border); font-size: var(--text-sm); }
.complexity tr:last-child td { border-bottom: none; }
.complexity .op { color: var(--text-dim); font-size: var(--text-xs); }
.good { color: var(--green);  font-family: var(--font-mono); font-weight: 700; }
.bad  { color: var(--red);    font-family: var(--font-mono); font-weight: 700; }
.ok   { color: var(--yellow); font-family: var(--font-mono); font-weight: 700; }

/* ─────────────────────────────────────────────
   § 14. Badge（小標籤）
   ───────────────────────────────────────────── */
.badge {
  display: inline-block; padding: 3px 10px; border-radius: 4px;
  font-family: var(--font-mono); font-size: var(--text-xs); font-weight: 700;
}
.badge.arr   { background: var(--array-dim);  color: var(--array-color);  border: 1px solid rgba(56,189,248,0.3); }
.badge.lnk   { background: var(--linked-dim); color: var(--linked-color); border: 1px solid rgba(251,146,60,0.3); }
.badge.stack { background: var(--stack-dim);  color: var(--stack-color);  border: 1px solid rgba(167,139,250,0.3); }
.badge.queue { background: var(--queue-dim);  color: var(--queue-color);  border: 1px solid rgba(52,211,153,0.3); }
.badge.tree  { background: var(--tree-dim);   color: var(--tree-color);   border: 1px solid rgba(52,211,153,0.3); }
.badge.adv   { background: var(--adv-glow);   color: var(--adv-color);    border: 1px solid var(--adv-border); }

/* ─────────────────────────────────────────────
   § 15. 視覺化區域
   ───────────────────────────────────────────── */
.viz {
  min-height: 90px; display: flex; align-items: center;
  flex-wrap: wrap; gap: 6px; position: relative;
}

/* ─────────────────────────────────────────────
   § 16. 效能比較 Bar
   ───────────────────────────────────────────── */
.compare-bar {
  background: var(--surface); border-radius: var(--radius-md);
  border: 1px solid var(--border);
  padding: 22px; margin-bottom: 24px;
}
.compare-bar h3 { font-size: var(--text-sm); color: var(--text-dim); margin-bottom: 16px; letter-spacing: 1px; }
.op-select { display: flex; gap: 10px; flex-wrap: wrap; margin-bottom: 20px; }
.op-btn {
  padding: 9px 18px; border-radius: var(--radius-sm); border: 1px solid var(--border);
  background: var(--surface2); color: var(--text-dim); cursor: pointer;
  font-size: var(--text-sm); transition: all 0.2s; font-family: var(--font-ui);
}
.op-btn.active { border-color: var(--yellow); color: var(--yellow); background: rgba(245,196,0,0.06); }
.speed-bars { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.speed-item label { font-size: var(--text-sm); margin-bottom: 8px; display: block; font-weight: 600; }
.bar-track { background: var(--surface2); border-radius: 4px; height: 24px; overflow: hidden; }
.bar-fill {
  height: 100%; border-radius: 4px; display: flex; align-items: center;
  padding: 0 12px; font-family: var(--font-mono); font-size: var(--text-xs); font-weight: 700;
  transition: width 0.7s cubic-bezier(0.4,0,0.2,1);
}
.bar-fill.arr  { background: linear-gradient(90deg, var(--array-color), #0ea5e9); color: #0A0F1A; }
.bar-fill.lnk  { background: linear-gradient(90deg, var(--linked-color), #f97316); color: #fff; }
.bar-fill.stack { background: linear-gradient(90deg, var(--stack-color), #7c3aed); color: #fff; }
.bar-fill.queue { background: linear-gradient(90deg, var(--queue-color), #10b981); color: #0A0F1A; }
.compare-note {
  margin-top: 16px; font-size: var(--text-sm); color: var(--text-dim);
  line-height: 1.8; padding: 12px 16px;
  background: var(--surface2); border-radius: var(--radius-sm);
}

/* ─────────────────────────────────────────────
   § 17. 記憶體示意圖
   ───────────────────────────────────────────── */
.memory-map { margin-top: 14px; }
.mem-label {
  font-size: var(--text-xs); color: var(--text-dim); font-family: var(--font-mono);
  margin-bottom: 8px; letter-spacing: 1px;
}
.mem-row { display: flex; gap: 4px; flex-wrap: wrap; }
.mem-cell {
  width: 42px; height: 36px; border-radius: 4px;
  border: 1px solid var(--border); background: var(--surface2);
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  font-family: var(--font-mono); font-size: var(--text-xs); color: var(--text-dim);
}
.mem-cell.used-arr    { border-color: var(--array-color);  color: var(--array-color);  background: var(--array-glow); }
.mem-cell.used-ll     { border-color: var(--linked-color); color: var(--linked-color); background: var(--linked-glow); }
.mem-cell.used-ll-ptr { border-color: var(--linked-color); color: rgba(251,146,60,0.5); background: rgba(251,146,60,0.04); }

/* ─────────────────────────────────────────────
   § 18. 連連看遊戲（MatchGame 引擎）
   ───────────────────────────────────────────── */
.match-header {
  display: flex; align-items: center; gap: 16px;
  background: var(--surface); border-radius: var(--radius-sm);
  padding: 14px 20px; margin-bottom: 20px;
  border: 1px solid var(--border);
}
.match-score-area { display: flex; flex-direction: column; }
.match-score-label { font-size: var(--text-xs); color: var(--text-dim); letter-spacing: 2px; font-family: var(--font-mono); }
.match-score { font-family: var(--font-mono); font-size: 24px; font-weight: 700; color: var(--yellow); }
.match-streak { flex: 1; font-size: 20px; letter-spacing: 2px; }

.match-arena {
  display: grid; grid-template-columns: 1fr 220px;
  gap: 20px; margin-bottom: 20px; align-items: start;
}
@media (max-width: 650px) { .match-arena { grid-template-columns: 1fr; } }

.match-col-label {
  font-size: var(--text-xs); letter-spacing: 2px; color: var(--text-dim);
  font-family: var(--font-mono); margin-bottom: 10px; text-transform: uppercase;
}
.match-scenarios { display: flex; flex-direction: column; gap: 8px; }

.scenario-card {
  background: var(--surface); border: 1.5px solid var(--border);
  border-radius: var(--radius-sm); padding: 13px 17px;
  cursor: grab; user-select: none;
  display: flex; align-items: center; gap: 12px;
  transition: all 0.2s; animation: slideIn 0.3s ease;
}
.scenario-card:hover      { border-color: var(--text-dim); transform: translateX(3px); }
.scenario-card.dragging   { opacity: 0.4; transform: scale(0.97); }
.scenario-card.selected   { border-color: var(--yellow); box-shadow: 0 0 0 2px rgba(245,196,0,0.15); transform: translateX(4px); }
.scenario-card.correct    { border-color: var(--green); background: rgba(34,197,94,0.05); cursor: default; opacity: 0.75; }
.scenario-card.wrong      { border-color: var(--red); background: rgba(239,68,68,0.05); animation: shake 0.4s ease; }
.scenario-card.correct:hover { transform: none; }

.sc-emoji { font-size: 24px; flex-shrink: 0; }
.sc-body  { flex: 1; }
.sc-title { font-size: var(--text-sm); font-weight: 700; margin-bottom: 2px; }
.sc-hint  { font-size: var(--text-xs); color: var(--text-dim); line-height: 1.5; }
.sc-check { font-size: 16px; flex-shrink: 0; }

.dropzones-col { display: flex; flex-direction: column; gap: 14px; }
.dropzone {
  border-radius: var(--radius-md); border: 2px dashed var(--border);
  background: var(--surface); transition: all 0.2s;
  cursor: pointer; min-height: 140px;
}
.dropzone:hover     { border-color: var(--text-mid); }
.dropzone.drag-over { border-color: var(--yellow); background: rgba(245,196,0,0.04); }
.dz-inner    { padding: 16px 14px; }
.dz-title    { font-size: var(--text-base); font-weight: 700; margin-bottom: 2px; }
.dz-subtitle { font-size: var(--text-xs); color: var(--text-dim); font-family: var(--font-mono); margin-bottom: 10px; }
.dz-matched  { display: flex; flex-direction: column; gap: 5px; }
.dz-chip {
  font-size: var(--text-xs); padding: 4px 9px; border-radius: 6px;
  display: flex; align-items: center; gap: 6px;
  animation: slideIn 0.25s ease;
}
.dz-chip.arr-chip   { background: var(--array-glow);  color: var(--array-color);  border: 1px solid rgba(56,189,248,0.25); }
.dz-chip.lnk-chip   { background: var(--linked-glow); color: var(--linked-color); border: 1px solid rgba(251,146,60,0.25); }
.dz-chip.stack-chip { background: var(--stack-glow);  color: var(--stack-color);  border: 1px solid rgba(167,139,250,0.25); }
.dz-chip.queue-chip { background: var(--queue-glow);  color: var(--queue-color);  border: 1px solid rgba(52,211,153,0.25); }
.dz-chip.tree-chip  { background: var(--tree-glow);   color: var(--tree-color);   border: 1px solid rgba(52,211,153,0.25); }

.match-feedback {
  border-radius: var(--radius-sm); padding: 14px 18px; font-size: var(--text-sm); line-height: 1.75;
  margin-bottom: 20px; animation: slideIn 0.3s ease; border: 1px solid;
}
.match-feedback.correct-fb { background: rgba(34,197,94,0.06);  border-color: var(--green); color: var(--green); }
.match-feedback.wrong-fb   { background: rgba(239,68,68,0.06);  border-color: var(--red);   color: #f87171; }
.match-feedback strong { display: block; font-size: var(--text-base); margin-bottom: 4px; }

.match-complete { text-align: center; padding: 40px 20px; animation: slideIn 0.5s ease; }
.complete-inner {
  display: inline-block; background: var(--surface);
  border-radius: var(--radius-lg); border: 1px solid var(--border); padding: 40px 52px;
}
.complete-emoji { font-size: 56px; margin-bottom: 12px; }
.complete-inner h3 { font-size: var(--text-xl); color: var(--yellow); margin-bottom: 8px; }
.complete-inner p  { color: var(--text-dim); font-size: var(--text-sm); }

/* ─────────────────────────────────────────────
   § 19. P3 鷹架理論 Onboarding（全站共用）
   ───────────────────────────────────────────── */
.onboard-overlay {
  position: fixed; inset: 0; z-index: 200;
  background: rgba(0,0,0,0.85);
  display: flex; align-items: center; justify-content: center;
  padding: 20px; animation: slideIn 0.4s ease;
}
.onboard-box {
  background: var(--surface); border-radius: var(--radius-lg);
  border: 1px solid var(--border);
  box-shadow: 0 0 60px rgba(0,0,0,0.5);
  max-width: 560px; width: 100%; padding: 40px 36px;
}
.onboard-step-indicator { display: flex; gap: 6px; margin-bottom: 28px; }
.onboard-pip {
  height: 4px; border-radius: 2px; flex: 1;
  background: var(--border); transition: background 0.3s;
}
.onboard-pip.done   { background: var(--green); }
.onboard-pip.active { background: var(--yellow); }
.onboard-icon  { font-size: 44px; margin-bottom: 14px; }
.onboard-title { font-size: var(--text-xl); font-weight: 700; margin-bottom: 10px; }
.onboard-body  { font-size: var(--text-base); color: var(--text); line-height: 1.8; margin-bottom: 22px; }
.onboard-task  {
  background: var(--surface2); border-radius: var(--radius-sm);
  border-left: 3px solid var(--yellow);
  padding: 13px 17px; font-size: var(--text-sm); color: var(--yellow);
  font-weight: 600; margin-bottom: 22px; line-height: 1.7;
}
.onboard-task strong { display: block; font-size: var(--text-xs); letter-spacing: 1px; opacity: 0.7; margin-bottom: 5px; }
.onboard-skip { font-size: var(--text-xs); color: var(--text-dim); background: none; border: none; cursor: pointer; text-decoration: underline; }

/* ─────────────────────────────────────────────
   § 20. P1 有益困難 — 預測框（全站共用）
   ───────────────────────────────────────────── */
.predict-box {
  background: var(--surface2); border-radius: var(--radius-sm);
  border: 1px solid rgba(245,196,0,0.35);
  padding: 14px 18px; margin-bottom: 14px;
  display: flex; align-items: center; gap: 12px; flex-wrap: wrap;
}
.predict-label { font-size: var(--text-sm); color: var(--yellow); font-weight: 700; flex-shrink: 0; }
.predict-input {
  padding: 7px 12px; border-radius: var(--radius-sm);
  border: 1px solid rgba(245,196,0,0.4); background: var(--bg);
  color: var(--yellow); font-family: var(--font-mono);
  font-size: var(--text-sm); font-weight: 700; text-align: center;
}
.predict-input:focus { outline: none; box-shadow: 0 0 8px rgba(245,196,0,0.3); }
.predict-hint  { font-size: var(--text-xs); color: var(--text-dim); }
.predict-result {
  margin-top: 8px; font-size: var(--text-sm); padding: 7px 13px;
  border-radius: var(--radius-sm); font-family: var(--font-mono); display: none;
}
.predict-result.hit  { background: rgba(34,197,94,0.08);  color: var(--green); border: 1px solid rgba(34,197,94,0.3); }
.predict-result.miss { background: rgba(239,68,68,0.08);  color: #f87171;      border: 1px solid rgba(239,68,68,0.3); }

/* ─────────────────────────────────────────────
   § 21. P4 概念轉變 — 前概念提問（全站共用）
   ───────────────────────────────────────────── */
.prior-banner {
  background: var(--surface); border-radius: var(--radius-md);
  border: 1px solid var(--border); padding: 26px 30px; margin-bottom: 32px;
  animation: slideIn 0.4s ease;
}
.prior-banner.hidden { display: none; }
.prior-q   { font-size: var(--text-lg); font-weight: 700; color: var(--yellow); margin-bottom: 8px; }
.prior-sub { font-size: var(--text-sm); color: var(--text-mid); margin-bottom: 20px; line-height: 1.8; }
.prior-choices { display: flex; gap: 10px; flex-wrap: wrap; }
.prior-btn {
  padding: 11px 22px; border-radius: var(--radius-sm);
  border: 1.5px solid var(--border); background: var(--surface2);
  color: var(--text); cursor: pointer; font-size: var(--text-sm);
  font-weight: 600; transition: all 0.2s; font-family: var(--font-ui);
}
.prior-btn:hover { border-color: var(--yellow); color: var(--yellow); }

.prior-review {
  background: var(--surface2); border-radius: var(--radius-sm);
  border: 1px solid rgba(245,196,0,0.3); padding: 20px 22px;
  margin-top: 22px; display: none; animation: slideIn 0.4s ease;
}
.prior-review h4 { color: var(--yellow); font-size: var(--text-base); margin-bottom: 12px; }
.prior-compare { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
@media(max-width:500px) { .prior-compare { grid-template-columns: 1fr; } }
.prior-col { background: var(--surface); border-radius: var(--radius-sm); padding: 14px 16px; }
.prior-col-label { font-size: var(--text-xs); letter-spacing: 2px; color: var(--text-dim); font-family: var(--font-mono); margin-bottom: 6px; }
.prior-col-val { font-size: var(--text-sm); font-weight: 600; }

/* ─────────────────────────────────────────────
   § 22. P2 後設認知 — 反思問答框（全站共用）
   ───────────────────────────────────────────── */
.reflect-box {
  margin-top: 32px; background: var(--surface);
  border-radius: var(--radius-md); border: 1px solid var(--border); overflow: hidden;
}
.reflect-header {
  padding: 15px 20px; background: var(--surface2);
  border-bottom: 1px solid var(--border);
  display: flex; align-items: center; gap: 8px;
}
.reflect-header-icon { font-size: 18px; }
.reflect-header-text { font-size: var(--text-sm); font-weight: 700; color: var(--text-mid); letter-spacing: 1px; }
.reflect-header-badge {
  font-family: var(--font-mono); font-size: var(--text-xs); padding: 2px 8px;
  border-radius: 10px; background: rgba(245,196,0,0.08); color: var(--yellow);
  border: 1px solid rgba(245,196,0,0.25);
}
.reflect-body { padding: 20px; }
.reflect-q { font-size: var(--text-base); color: var(--text); margin-bottom: 14px; line-height: 1.8; font-weight: 600; }
.reflect-textarea {
  width: 100%; min-height: 80px; padding: 11px 15px;
  border-radius: var(--radius-sm); border: 1px solid var(--border);
  background: var(--surface2); color: var(--text);
  font-family: var(--font-ui); font-size: var(--text-sm); line-height: 1.7;
  resize: vertical; transition: border-color 0.2s;
}
.reflect-textarea:focus { outline: none; border-color: var(--yellow); }
.reflect-submit {
  margin-top: 11px; padding: 9px 22px; border-radius: var(--radius-sm);
  border: 1px solid rgba(245,196,0,0.35); background: rgba(245,196,0,0.06);
  color: var(--yellow); cursor: pointer; font-size: var(--text-sm);
  font-weight: 600; font-family: var(--font-ui); transition: all 0.2s;
}
.reflect-submit:hover { background: rgba(245,196,0,0.14); }
.reflect-answer {
  margin-top: 16px; background: var(--surface2); border-radius: var(--radius-sm);
  border-left: 3px solid var(--green); padding: 13px 17px;
  display: none; animation: slideIn 0.3s ease;
}
.reflect-answer-label { font-size: var(--text-xs); letter-spacing: 2px; color: var(--green); font-family: var(--font-mono); margin-bottom: 6px; }
.reflect-answer-text  { font-size: var(--text-sm); color: var(--text); line-height: 1.8; }
.reflect-self-rate { margin-top: 16px; display: none; animation: slideIn 0.3s ease; }
.reflect-rate-label { font-size: var(--text-sm); color: var(--text-dim); margin-bottom: 9px; }
.rate-btns  { display: flex; gap: 8px; }
.rate-btn {
  flex: 1; padding: 9px 4px; border-radius: var(--radius-sm);
  border: 1px solid var(--border); background: var(--surface2);
  color: var(--text-dim); cursor: pointer; font-size: var(--text-sm);
  font-family: var(--font-ui); transition: all 0.2s; text-align: center;
}
.rate-btn:hover { border-color: var(--yellow); color: var(--yellow); }
.rate-btn.selected { font-weight: 700; }
.rate-btn[data-r="1"].selected { border-color: var(--red);    background: rgba(239,68,68,0.08);  color: #f87171; }
.rate-btn[data-r="2"].selected { border-color: var(--yellow); background: rgba(245,196,0,0.08); color: var(--yellow); }
.rate-btn[data-r="3"].selected { border-color: var(--green);  background: rgba(34,197,94,0.08);  color: var(--green); }
.reflect-done-msg { margin-top: 10px; font-size: var(--text-sm); color: var(--green); display: none; font-family: var(--font-mono); }

/* ─────────────────────────────────────────────
   § 23. 進度追蹤膠囊
   ───────────────────────────────────────────── */
.progress-pill {
  position: fixed; top: 64px; right: 16px; z-index: 50;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: 20px; padding: 7px 15px;
  display: flex; align-items: center; gap: 8px;
  font-size: var(--text-xs); color: var(--text-dim); font-family: var(--font-mono);
  box-shadow: 0 2px 16px rgba(0,0,0,0.35);
}
.pill-dots   { display: flex; gap: 4px; }
.pill-dot    { width: 8px; height: 8px; border-radius: 50%; background: var(--border); transition: background 0.4s; }
.pill-dot.done   { background: var(--green); box-shadow: 0 0 5px var(--green); }
.pill-dot.active { background: var(--yellow); }

/* ─────────────────────────────────────────────
   § 24. ══ 進階學習者元件（.adv-* 系列）══
   ───────────────────────────────────────────── */

/* 進階切換按鈕（右上角浮動）*/
.adv-toggle-wrap {
  display: flex; justify-content: flex-end; margin-bottom: 20px;
}
.adv-toggle {
  display: flex; align-items: center; gap: 8px;
  padding: 7px 16px; border-radius: 20px;
  border: 1px solid var(--adv-border); background: var(--adv-glow);
  color: var(--adv-color); cursor: pointer; font-size: var(--text-sm);
  font-family: var(--font-ui); font-weight: 600; transition: all 0.2s;
}
.adv-toggle:hover { background: rgba(129,140,248,0.18); }
.adv-toggle .adv-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--adv-color); transition: all 0.2s;
}
.adv-toggle.active .adv-dot { box-shadow: 0 0 8px var(--adv-color); }

/* 進階內容容器 — 預設隱藏 */
.adv-section {
  display: none;
  border: 1px solid var(--adv-border);
  border-radius: var(--radius-md);
  background: linear-gradient(135deg, rgba(129,140,248,0.04), transparent);
  margin-top: 20px;
  animation: slideIn 0.35s ease;
  overflow: hidden;
}
.adv-section.visible { display: block; }

.adv-header {
  padding: 14px 20px; border-bottom: 1px solid var(--adv-border);
  display: flex; align-items: center; gap: 10px;
  background: rgba(129,140,248,0.06);
}
.adv-header-icon { font-size: 18px; }
.adv-header-title { font-size: var(--text-base); font-weight: 700; color: var(--adv-color); }
.adv-header-badge {
  font-size: var(--text-xs); padding: 2px 9px; border-radius: 10px;
  background: var(--adv-glow); color: var(--adv-color);
  border: 1px solid var(--adv-border); font-family: var(--font-mono); font-weight: 700;
}
.adv-body { padding: 22px; }

/* 程式碼區塊 */
.code-block {
  background: #0d1117;
  border: 1px solid var(--adv-border);
  border-radius: var(--radius-sm);
  padding: 18px 20px;
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  line-height: 1.75;
  overflow-x: auto;
  margin: 14px 0;
  position: relative;
}
.code-block .lang-tag {
  position: absolute; top: 10px; right: 14px;
  font-size: var(--text-xs); color: var(--text-dim);
  letter-spacing: 1px; text-transform: uppercase;
}
/* 語法高亮色（靜態，不需 library）*/
.code-block .kw  { color: #c792ea; }  /* keyword: class, def, return */
.code-block .fn  { color: #82aaff; }  /* function name */
.code-block .str { color: #c3e88d; }  /* string */
.code-block .num { color: #f78c6c; }  /* number */
.code-block .cmt { color: #546e7a; font-style: italic; } /* comment */
.code-block .tp  { color: var(--adv-color); }  /* type */
.code-block .op  { color: var(--yellow); }      /* operator, arrow */

/* 複雜度說明列 */
.adv-complexity-row {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 14px; border-radius: var(--radius-sm);
  background: var(--surface2); border: 1px solid var(--border);
  margin-bottom: 8px;
}
.adv-complexity-row .op-name { font-size: var(--text-sm); font-weight: 600; flex: 1; }
.adv-complexity-row .big-o {
  font-family: var(--font-mono); font-size: var(--text-sm); font-weight: 700;
  padding: 3px 10px; border-radius: 4px;
}
.adv-complexity-row .big-o.O1  { color: var(--green);  background: rgba(34,197,94,0.08);  border: 1px solid rgba(34,197,94,0.2); }
.adv-complexity-row .big-o.On  { color: var(--red);    background: rgba(239,68,68,0.08);  border: 1px solid rgba(239,68,68,0.2); }
.adv-complexity-row .big-o.Ologn{ color: var(--yellow);background: rgba(245,196,0,0.08); border: 1px solid rgba(245,196,0,0.2); }
.adv-complexity-row .reason { font-size: var(--text-xs); color: var(--text-dim); flex: 2; }

/* 互動程式模擬器 */
.code-sim {
  background: var(--surface2); border-radius: var(--radius-md);
  border: 1px solid var(--adv-border); overflow: hidden; margin: 14px 0;
}
.code-sim-header {
  padding: 10px 16px; border-bottom: 1px solid var(--adv-border);
  display: flex; align-items: center; gap: 8px;
  font-size: var(--text-xs); color: var(--adv-color);
  font-family: var(--font-mono); letter-spacing: 1px;
}
.code-sim-body { display: grid; grid-template-columns: 1fr 1fr; }
@media(max-width:700px){ .code-sim-body { grid-template-columns: 1fr; } }
.code-sim-code { padding: 16px; border-right: 1px solid var(--adv-border); }
.code-sim-viz  { padding: 16px; }
.code-sim-line {
  display: flex; align-items: center; gap: 10px;
  padding: 4px 8px; border-radius: 4px;
  font-family: var(--font-mono); font-size: var(--text-xs);
  color: var(--text-dim); cursor: pointer; transition: all 0.15s;
}
.code-sim-line:hover { background: rgba(129,140,248,0.08); color: var(--text); }
.code-sim-line.active { background: rgba(129,140,248,0.15); color: var(--adv-color); }
.code-sim-line .line-num { color: var(--text-dim); width: 18px; text-align: right; flex-shrink: 0; }
.code-sim-line .line-arrow { color: var(--adv-color); flex-shrink: 0; font-size: 10px; opacity: 0; }
.code-sim-line.active .line-arrow { opacity: 1; }

/* 進階題型 Challenge */
.adv-challenge {
  background: var(--surface2); border-radius: var(--radius-sm);
  border: 1px solid var(--adv-border); padding: 16px 20px; margin-top: 14px;
}
.adv-challenge-title {
  font-size: var(--text-sm); font-weight: 700; color: var(--adv-color);
  margin-bottom: 8px; display: flex; align-items: center; gap: 8px;
}
.adv-challenge p { font-size: var(--text-sm); color: var(--text-mid); line-height: 1.8; margin-bottom: 10px; }
.adv-challenge-hint {
  font-size: var(--text-xs); color: var(--text-dim); font-family: var(--font-mono);
  padding: 8px 12px; border-radius: 6px; background: var(--surface);
  border: 1px solid var(--border); cursor: pointer; transition: all 0.2s;
  display: inline-block;
}
.adv-challenge-hint:hover { border-color: var(--adv-border); color: var(--adv-color); }

/* ─────────────────────────────────────────────
   § 25. 學習流程標示（P1–P4 徽章）
   ───────────────────────────────────────────── */
.psych-badge {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 2px 9px; border-radius: 10px; font-size: var(--text-xs);
  font-family: var(--font-mono); font-weight: 700; letter-spacing: 0.5px;
  vertical-align: middle; margin-left: 6px;
}
.psych-badge.p1 { background: rgba(245,196,0,0.1);  color: var(--yellow); border: 1px solid rgba(245,196,0,0.25); }
.psych-badge.p2 { background: rgba(34,197,94,0.08);  color: var(--green);  border: 1px solid rgba(34,197,94,0.2); }
.psych-badge.p3 { background: rgba(56,189,248,0.08); color: var(--array-color); border: 1px solid rgba(56,189,248,0.2); }
.psych-badge.p4 { background: rgba(251,146,60,0.08); color: var(--linked-color); border: 1px solid rgba(251,146,60,0.2); }

/* ─────────────────────────────────────────────
   § 26. Keyframe 動畫
   ───────────────────────────────────────────── */
@keyframes pulse-arr {
  0%   { box-shadow: 0 0 0 0   rgba(56,189,248,0.5); }
  50%  { box-shadow: 0 0 16px 4px rgba(56,189,248,0.3); }
  100% { box-shadow: 0 0 0 0   rgba(56,189,248,0); }
}
@keyframes shake {
  0%,100% { transform: translateX(0); }
  25%     { transform: translateX(-5px); }
  75%     { transform: translateX(5px); }
}
@keyframes slideIn {
  from { opacity: 0; transform: translateY(-10px) scale(0.97); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}
@keyframes fadeOut {
  from { opacity: 1; transform: translateX(0); }
  to   { opacity: 0; transform: translateX(30px); }
}
.slide-in { animation: slideIn 0.3s ease; }

/* ─────────────────────────────────────────────
   § 27. Word Bank 術語庫
   ───────────────────────────────────────────── */
.wordbank-bar {
  background: var(--surface); border-radius: var(--radius-md);
  border: 1px solid var(--border); padding: 16px 22px; margin-bottom: 28px;
}
.wordbank-title {
  font-size: var(--text-xs); letter-spacing: 3px; color: var(--text-dim);
  font-family: var(--font-mono); text-transform: uppercase;
  margin-bottom: 12px; display: flex; align-items: center; gap: 8px;
}
.wordbank-title::before { content: '📖'; font-size: 14px; }
.wordbank-chips { display: flex; gap: 8px; flex-wrap: wrap; }
.wb-chip {
  padding: 5px 14px; border-radius: 20px; cursor: pointer;
  font-size: var(--text-sm); font-weight: 600; font-family: var(--font-ui);
  border: 1.5px solid; transition: all 0.2s; user-select: none;
}
.wb-chip.arr-term  { color: var(--array-color);  border-color: rgba(56,189,248,0.4);  background: var(--array-dim); }
.wb-chip.lnk-term  { color: var(--linked-color); border-color: rgba(251,146,60,0.4);  background: var(--linked-dim); }
.wb-chip.gen-term  { color: var(--yellow);        border-color: rgba(245,196,0,0.4);   background: rgba(245,196,0,0.05); }
.wb-chip:hover, .wb-chip.open { filter: brightness(1.2); transform: translateY(-1px); }
.wb-popup {
  position: fixed; z-index: 300;
  background: var(--surface); border-radius: var(--radius-md);
  border: 1.5px solid var(--border);
  box-shadow: 0 12px 50px rgba(0,0,0,0.55);
  padding: 22px 24px; max-width: 380px; width: 92%;
  max-height: 80vh; overflow-y: auto;
  animation: slideIn 0.22s ease;
}
.wb-popup-term  { font-size: var(--text-lg); font-weight: 700; margin-bottom: 6px; }
.wb-popup-en    { font-size: var(--text-xs); font-family: var(--font-mono); color: var(--text-dim); letter-spacing: 1px; margin-bottom: 10px; }
.wb-popup-def   { font-size: var(--text-sm); color: var(--text); line-height: 1.8; margin-bottom: 10px; }
.wb-popup-ex    { font-size: var(--text-xs); color: var(--text-dim); font-family: var(--font-mono); background: var(--surface2); border-radius: 6px; padding: 9px 13px; border-left: 3px solid currentColor; line-height: 1.7; }
.wb-popup-close { position: absolute; top: 12px; right: 14px; background: none; border: none; cursor: pointer; font-size: 16px; color: var(--text-dim); }
.wb-backdrop    { position: fixed; inset: 0; z-index: 299; background: transparent; }

/* ─────────────────────────────────────────────
   § 28. 故事框
   ───────────────────────────────────────────── */
.story-box {
  background: var(--surface2); border-radius: var(--radius-sm);
  padding: 16px 20px; margin-bottom: 20px;
  border: 1px solid var(--border);
  font-size: var(--text-sm); line-height: 1.85; color: var(--text);
}
.story-box .q {
  color: var(--yellow); font-weight: 700;
  display: block; margin-bottom: 8px;
}
