/* 各頁版面 */

/* ===== 首頁闖關地圖 ===== */
.unit-block{ margin-bottom:var(--space-xl); }
.unit-title{
  display:flex; align-items:center; gap:.6rem;
  font-size:var(--fs-h1); font-weight:800; margin-bottom:var(--space);
}
.unit-title .dot{ width:16px;height:16px;border-radius:50%; }
.unit-title .unit-mm-btn{ margin-left:auto; font-size:.95rem; padding:.4rem 1rem; min-height:0; box-shadow:none; }
@media(max-width:520px){ .unit-title{ flex-wrap:wrap; } .unit-title .unit-mm-btn{ margin-left:0; } }
.u-transport .dot{ background:var(--c-transport); }
.u-scenery .dot{ background:var(--c-scenery); }

.map{ display:grid; gap:var(--space-lg); }
@media(min-width:760px){ .map{ grid-template-columns:repeat(2,1fr); } }

.level{
  display:flex; align-items:center; gap:var(--space);
  text-align:left; position:relative; overflow:hidden;
}
.level .face{
  width:64px;height:64px;flex:0 0 64px;
  display:flex;align-items:center;justify-content:center;
  font-size:2rem;border-radius:var(--radius-sm);
}
.u-transport .level .face{ background:var(--c-transport-soft); }
.u-scenery .level .face{ background:var(--c-scenery-soft); }
.level .body{ flex:1; min-width:0; }
.level .body h3{ font-size:var(--fs-h2); margin:0 0 .2rem; }
.level .go{ flex:0 0 auto; }

/* ===== 課程頁 ===== */
.lesson-hero{ text-align:center; padding:var(--space-lg) 0; }
.lesson-hero .big{ font-size:3.4rem; }
.lesson-hero h1{ font-size:var(--fs-display); }
.lesson-hero-img{
  width:100%; max-width:560px; height:auto; margin:.6rem auto;
  border-radius:var(--radius); box-shadow:var(--shadow);
  border:1px solid var(--c-line);
}

.section-title{ display:flex;align-items:center;gap:.5rem; font-size:var(--fs-h1); margin:var(--space-xl) 0 var(--space); }

.points{ list-style:none; padding:0; display:grid; gap:.8rem; }
.points li{
  display:flex; align-items:flex-start; gap:.8rem;
  background:#fff; border:1px solid var(--c-line); border-radius:var(--radius-sm);
  padding:.9rem 1rem; box-shadow:var(--shadow);
}
.points .pi{ font-size:1.8rem; line-height:1.2; flex:0 0 auto; }

/* 心智圖 */
.mindmap{ display:grid; gap:.8rem; }
.mm-root{
  justify-self:center; background:var(--c-ink); color:#fff;
  padding:.6rem 1.2rem; border-radius:var(--radius-pill); font-weight:800; font-size:1.2rem;
}
.mm-branches{ display:grid; gap:.8rem; }
@media(min-width:640px){ .mm-branches{ grid-template-columns:repeat(2,1fr); } }
.mm-branch{ background:#fff;border:1px solid var(--c-line);border-radius:var(--radius-sm);padding:.8rem 1rem;box-shadow:var(--shadow); }
.mm-branch > b{ display:block; font-size:1.1rem; margin-bottom:.3rem; }
.mm-branch ul{ margin:0; }

/* 記憶卡 */
.cards-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:.8rem; }
@media(min-width:520px){ .cards-grid{ grid-template-columns:repeat(3,1fr); } }
.mcard{
  background:#fff;border:1px solid var(--c-line);border-radius:var(--radius-sm);
  padding:1rem .6rem; text-align:center; box-shadow:var(--shadow);
}
.mcard .e{ font-size:2.4rem; line-height:1; }
.mcard .t{ font-weight:700; margin-top:.4rem; }

/* 行動列 */
.actions{ display:grid; gap:.8rem; margin:var(--space-xl) 0; }
@media(min-width:520px){ .actions{ grid-template-columns:1fr 1fr; } }

/* 錯誤頁 */
.err{ text-align:center; padding:var(--space-xl); }
.err .big{ font-size:3rem; }

/* ===== 練習題頁 ===== */
.quiz-top{ display:flex; align-items:center; gap:.6rem; margin-bottom:var(--space-lg); }
.quiz-top .qcount{ font-weight:800; color:var(--c-ink-soft); white-space:nowrap; }
.quiz-card{ }
.qtype{ display:inline-block; font-weight:800; color:var(--c-ink-soft); margin-bottom:.4rem; }
.qtext{ font-size:var(--fs-h1); margin-bottom:var(--space-lg); }
.qbody{ display:grid; gap:.7rem; }

/* 選項 / 是非 */
.opt{
  width:100%; text-align:left; font-size:var(--fs-btn); font-weight:700;
  min-height:var(--tap); padding:.8rem 1.1rem;
  background:#fff; color:var(--c-ink); border:2px solid var(--c-line);
  border-radius:var(--radius-sm); transition:transform .1s, border-color .1s, background .1s;
}
.opt:hover:not(:disabled){ transform:translateX(3px); border-color:var(--c-transport); }
.opt-tf{ text-align:center; font-size:1.4rem; }
.opt-right{ background:#E9FBEF; border-color:var(--c-success); color:#15803D; }
.opt-wrong{ background:#FDECEC; border-color:var(--c-error); color:#B91C1C; }
.opt:disabled{ cursor:default; }

/* 回饋 */
.feedback{ margin-top:var(--space-lg); display:grid; gap:.8rem; }
.result{ padding:.9rem 1.1rem; border-radius:var(--radius-sm); font-weight:800; font-size:var(--fs-btn); }
.result.ok{ background:#E9FBEF; color:#15803D; }
.result.no{ background:#FDECEC; color:#B91C1C; }
.result .explain{ font-weight:600; font-size:var(--fs-body); margin:.4rem 0 0; color:var(--c-ink); }
.hint{ margin:0; }

/* 配對題 */
.match-grid{ grid-template-columns:1fr 1fr; gap:1rem; }
.match-col{ display:grid; gap:.6rem; }
.mtile{
  min-height:var(--tap); padding:.7rem; font-size:1.2rem; font-weight:700;
  background:#fff; border:2px solid var(--c-line); border-radius:var(--radius-sm);
}
.mtile.sel{ border-color:var(--c-transport); background:var(--c-transport-soft); }
.mtile.matched{ background:#E9FBEF; border-color:var(--c-success); color:#15803D; cursor:default; }
.mtile.shake{ animation:shake .4s; }
@keyframes shake{ 0%,100%{transform:translateX(0);} 25%{transform:translateX(-6px);} 75%{transform:translateX(6px);} }

/* 排序題 */
.order-body{ gap:1rem; }
.order-line{ min-height:52px; display:flex; flex-wrap:wrap; gap:.5rem; align-items:center;
  background:#fff; border:2px dashed var(--c-line); border-radius:var(--radius-sm); padding:.6rem; }
.order-slot{ background:var(--c-transport); color:#fff; padding:.4rem .8rem; border-radius:var(--radius-pill); font-weight:700; }
.order-pool{ display:flex; flex-wrap:wrap; gap:.6rem; }
.otile{ font-size:1.15rem; font-weight:700; padding:.6rem 1rem; background:#fff;
  border:2px solid var(--c-line); border-radius:var(--radius-sm); }
.otile.used{ opacity:.35; }

/* 結算 */
.quiz-result .big{ font-size:3.4rem; }
.quiz-result .praise{ font-size:var(--fs-h2); font-weight:700; }
.got-badge{ background:var(--c-scenery-soft); color:#B45309; font-weight:800;
  display:inline-block; padding:.5rem 1rem; border-radius:var(--radius-pill); }

/* ===== 成就頁 ===== */
.ach-summary .big{ font-size:2.6rem; }
.badge-wall{ display:grid; grid-template-columns:repeat(2,1fr); gap:.8rem; }
@media(min-width:560px){ .badge-wall{ grid-template-columns:repeat(3,1fr); } }
@media(min-width:820px){ .badge-wall{ grid-template-columns:repeat(5,1fr); } }
.badge-big{
  background:#fff; border:2px solid var(--c-line); border-radius:var(--radius);
  padding:1rem .6rem; text-align:center; box-shadow:var(--shadow);
}
.badge-big.locked{ filter:grayscale(1); opacity:.55; }
.badge-big .bb-ico{ font-size:2.6rem; line-height:1; }
.badge-big .bb-name{ font-weight:800; margin:.3rem 0; }
.badge-big .bb-cond{ font-size:.8rem; line-height:1.3; }
.badge-big .bb-state{ font-size:.85rem; font-weight:700; margin-top:.4rem; color:var(--c-success); }
.badge-big.locked .bb-state{ color:var(--c-ink-soft); }

.lesson-list{ display:grid; gap:.6rem; }
.lesson-row{ display:flex; align-items:center; gap:.8rem; }
.lesson-row .lr-emoji{ font-size:1.8rem; }
.lesson-row .lr-title{ flex:1; font-weight:700; }

/* ===== 台灣特產地圖（u4l2） — 插畫圖 ===== */
.tw-map-link{ display:block; max-width:720px; margin:0 auto; }
.tw-map-img{
  width:100%; height:auto; display:block;
  border:1px solid var(--c-line); border-radius:var(--radius);
  box-shadow:var(--shadow); background:#fff;
  transition:transform .15s, box-shadow .15s;
}
.tw-map-link:hover .tw-map-img{ transform:scale(1.01); box-shadow:var(--shadow-lg); }

/* ===== 放射狀心智圖（mm2，每課/每單元共用） ===== */
.mm2{ position:relative; padding:.5rem 0; }
.mm2-svg{ position:absolute; inset:0; pointer-events:none; z-index:0; }
.mm2-line{ fill:none; stroke-width:3; stroke-linecap:round; }
.mm2[data-theme="transport"] .mm2-line{ stroke:var(--c-transport); opacity:.45; }
.mm2[data-theme="scenery"]  .mm2-line{ stroke:var(--c-scenery);  opacity:.5; }

.mm2-row{ position:relative; z-index:1; display:grid;
  grid-template-columns:1fr auto 1fr; align-items:center; gap:1.6rem; }
.mm2-col{ display:grid; gap:1rem; align-content:center; }
.mm2-col-left{ justify-items:end; text-align:right; }
.mm2-col-right{ justify-items:start; text-align:left; }

.mm2-center{ display:flex; justify-content:center; }
.mm2-root{
  background:var(--c-ink); color:#fff; font-weight:800; font-size:1.25rem;
  padding:.85rem 1.3rem; border-radius:var(--radius-pill); text-align:center;
  box-shadow:var(--shadow-lg); white-space:nowrap;
}
.mm2[data-theme="transport"] .mm2-root{ background:var(--c-transport); }
.mm2[data-theme="scenery"]  .mm2-root{ background:var(--c-scenery); }

.mm2-branch{
  background:#fff; border:2px solid var(--c-line); border-radius:var(--radius-sm);
  padding:.55rem .85rem; box-shadow:var(--shadow); max-width:250px; display:inline-block;
}
.mm2[data-theme="transport"] .mm2-branch{ border-color:#BFDBFE; }
.mm2[data-theme="scenery"]  .mm2-branch{ border-color:#FCD9A8; }
.mm2-branch-label{ font-weight:800; font-size:1.05rem; }
.mm2-branch ul{ margin:.2rem 0 0; padding-left:1.1em; }
.mm2-col-left .mm2-branch ul{ padding-left:0; padding-right:1.1em; list-style-position:inside; }

/* 手機：隱藏連線、中心在上、分支垂直堆疊 */
@media(max-width:640px){
  .mm2-svg{ display:none; }
  .mm2-row{ grid-template-columns:1fr; gap:.7rem; }
  .mm2-center{ order:-1; margin-bottom:.3rem; }
  .mm2-col-left, .mm2-col-right{ justify-items:stretch; text-align:left; }
  .mm2-col-left .mm2-branch ul{ padding-left:1.1em; padding-right:0; list-style-position:outside; }
  .mm2-branch{ max-width:none; display:block; }
}
