:root{
  --bg:#f5f2ec;          /* 溫潤米白 */
  --card:#ffffff;
  --ink:#2c2a26;         /* 近黑墨 */
  --ink-soft:#6f6a60;
  --line:#e7e1d6;
  --gold:#bfa06a;        /* 香檳金（點綴，不喧賓奪主）*/
  --gold-deep:#9a7f4e;
  --good:#5b8c5a;
  --bad:#c2614f;
  --shadow:0 8px 28px rgba(60,52,38,.10);
  --radius:18px;
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{height:100%}
body{
  font-family:-apple-system,"PingFang TC","Hiragino Sans","Noto Sans TC",system-ui,sans-serif;
  background:var(--bg); color:var(--ink);
  line-height:1.5; overscroll-behavior-y:none;
  padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left);
}
#app{max-width:560px;margin:0 auto;min-height:100%;display:flex;flex-direction:column}
.screen{flex:1;padding:22px 18px 40px;animation:fade .25s ease}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.hidden{display:none!important}

/* 頂列 */
header.bar{display:flex;align-items:center;gap:12px;padding:16px 18px 4px;position:sticky;top:0;z-index:5}
.brand{display:flex;align-items:center;gap:9px;font-weight:700;letter-spacing:.5px}
.brand .mark{color:var(--gold);font-size:20px}
.brand small{color:var(--ink-soft);font-weight:500;letter-spacing:0}
.back{margin-left:auto;border:1px solid var(--line);background:var(--card);color:var(--ink-soft);
  border-radius:999px;padding:8px 15px;font-size:14px;cursor:pointer;font-weight:600}
.back:active{transform:scale(.96)}

/* 首頁 */
.hero{margin:8px 2px 22px}
.hero h1{font-size:27px;font-weight:800;letter-spacing:.5px;line-height:1.25}
.hero h1 .jp{color:var(--gold-deep)}
.hero p{color:var(--ink-soft);margin-top:8px;font-size:15px}
.lesson-grid{display:flex;flex-direction:column;gap:14px}
.lesson{display:flex;align-items:center;gap:15px;background:var(--card);border:1px solid var(--line);
  border-radius:var(--radius);padding:17px 18px;box-shadow:var(--shadow);cursor:pointer;
  transition:transform .12s ease}
.lesson:active{transform:scale(.985)}
.lesson .ico{font-size:30px;width:46px;text-align:center;flex:none}
.lesson .meta{min-width:0;flex:1}
.lesson .meta h3{font-size:18px;font-weight:700}
.lesson .meta p{color:var(--ink-soft);font-size:13.5px;margin-top:2px}
.lesson .count{margin-left:auto;flex:none;color:var(--gold-deep);font-weight:700;font-size:13px;
  border:1px solid var(--line);border-radius:999px;padding:4px 11px}
.resource{margin-top:24px;background:linear-gradient(180deg,#fbf8f1,#fff);border:1px dashed var(--gold);
  border-radius:var(--radius);padding:16px 18px}
.resource h4{font-size:14px;color:var(--gold-deep);font-weight:700;margin-bottom:7px}
.resource a{display:block;color:var(--ink);text-decoration:none;font-size:14px;padding:7px 0;
  border-bottom:1px solid var(--line)}
.resource a:last-child{border-bottom:0}
.resource a::before{content:"📺  "}
.resource .note{font-size:12px;color:var(--ink-soft);margin-top:9px;line-height:1.55}

/* 課程選單（學習 / 練習）*/
.modechoose{display:flex;flex-direction:column;gap:14px;margin-top:18px}
.modecard{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:20px;box-shadow:var(--shadow);cursor:pointer;transition:transform .12s}
.modecard:active{transform:scale(.985)}
.modecard h3{font-size:19px;font-weight:700;display:flex;align-items:center;gap:9px}
.modecard p{color:var(--ink-soft);font-size:14px;margin-top:6px}

/* 進度條 */
.progress{height:6px;background:var(--line);border-radius:999px;overflow:hidden;margin:4px 2px 18px}
.progress > i{display:block;height:100%;background:linear-gradient(90deg,var(--gold),var(--gold-deep));
  width:0;transition:width .35s ease}

/* 學習卡 */
.flash{background:var(--card);border:1px solid var(--line);border-radius:24px;box-shadow:var(--shadow);
  padding:30px 22px 26px;text-align:center;margin-bottom:18px}
.flash .jp{font-size:34px;font-weight:700;letter-spacing:1px;line-height:1.35}
.flash .kana{font-size:17px;color:var(--ink-soft);margin-top:12px}
.flash .romaji{font-size:15px;color:var(--gold-deep);margin-top:5px;font-style:italic;letter-spacing:.5px}
.flash .zh{font-size:19px;margin-top:16px;font-weight:600}
.flash .tip{margin-top:14px;font-size:13px;color:var(--ink-soft);background:#faf6ee;border-radius:12px;
  padding:9px 12px;display:inline-block}
.grammar{background:#fbf8f1;border-left:3px solid var(--gold);border-radius:0 12px 12px 0;
  padding:12px 14px;margin-bottom:18px;font-size:14px;color:#544f46;line-height:1.6}
.grammar b{color:var(--gold-deep)}
.grammar a.vlink{display:inline-block;margin-top:8px;color:var(--gold-deep);font-weight:700;
  text-decoration:none;font-size:13px}
.grammar a.vlink::before{content:"📺 "}

/* 按鈕 */
.btn{display:block;width:100%;border:0;border-radius:14px;padding:16px;font-size:17px;font-weight:700;
  cursor:pointer;font-family:inherit;transition:transform .1s}
.btn:active{transform:scale(.98)}
.btn.gold{background:var(--gold);color:#fff;box-shadow:0 6px 16px rgba(191,160,106,.4)}
.btn.ghost{background:var(--card);color:var(--ink);border:1px solid var(--line)}
.btn-row{display:flex;gap:12px;margin-top:10px}
.btn-row .btn{flex:1}
.speak{display:inline-flex;align-items:center;justify-content:center;gap:8px;background:var(--card);
  border:1px solid var(--gold);color:var(--gold-deep);border-radius:999px;padding:11px 20px;font-size:15px;
  font-weight:700;cursor:pointer;margin:2px auto 0}
.speak:active{transform:scale(.96)}
.speak.big{font-size:18px;padding:14px 26px}

/* 練習：聽力選擇 */
.q-prompt{text-align:center;color:var(--ink-soft);font-size:14px;margin-bottom:6px}
.q-card{background:var(--card);border:1px solid var(--line);border-radius:24px;box-shadow:var(--shadow);
  padding:28px 20px;text-align:center;margin-bottom:18px}
.options{display:flex;flex-direction:column;gap:12px}
.option{background:var(--card);border:1.5px solid var(--line);border-radius:14px;padding:16px;font-size:17px;
  text-align:left;cursor:pointer;font-family:inherit;transition:transform .1s,border-color .15s,background .15s}
.option:active{transform:scale(.99)}
.option.correct{border-color:var(--good);background:#eef6ee}
.option.wrong{border-color:var(--bad);background:#f9ecea}
.option.dim{opacity:.5}

/* 跟讀 */
.shadow-jp{font-size:30px;font-weight:700;text-align:center;line-height:1.4}
.shadow-kana{text-align:center;color:var(--ink-soft);margin-top:8px}
.shadow-romaji{text-align:center;color:var(--gold-deep);font-style:italic;margin-top:3px}
.rec-row{display:flex;gap:12px;margin-top:18px}
.rec-row button{flex:1;border-radius:14px;padding:15px;font-size:15px;font-weight:700;font-family:inherit;
  cursor:pointer;border:1px solid var(--line);background:var(--card)}
.rec-row button.recording{background:#f9ecea;border-color:var(--bad);color:var(--bad);animation:pulse 1s infinite}
@keyframes pulse{50%{opacity:.55}}
.rec-row button:disabled{opacity:.4}
.playback{margin-top:14px;text-align:center}
.playback audio{width:100%;margin-top:8px}
.hint{text-align:center;font-size:13px;color:var(--ink-soft);margin-top:12px;line-height:1.6}

/* 完成頁 */
.done{text-align:center;padding-top:30px}
.done .big{font-size:54px}
.done h2{font-size:24px;margin:14px 0 8px}
.done p{color:var(--ink-soft);margin-bottom:26px}

footer.tip-foot{text-align:center;color:var(--ink-soft);font-size:12px;padding:18px;opacity:.8}

/* ===== 學習路徑 區段標題 ===== */
.path-head{display:flex;align-items:baseline;gap:9px;margin:26px 2px 13px;font-size:17px;font-weight:800}
.path-head:first-of-type{margin-top:6px}
.path-head .dot{display:inline-flex;align-items:center;justify-content:center;width:25px;height:25px;
  background:var(--gold);color:#fff;border-radius:999px;font-size:13px;font-weight:700;flex:none}
.path-head small{color:var(--ink-soft);font-weight:500;font-size:13px}

/* 地基卡 */
.base-grid{display:flex;flex-direction:column;gap:12px}
.basecard{display:flex;align-items:center;gap:14px;background:linear-gradient(180deg,#fbf8f1,#fff);
  border:1px solid var(--line);border-radius:var(--radius);padding:15px 17px;box-shadow:var(--shadow);
  cursor:pointer;transition:transform .12s}
.basecard:active{transform:scale(.985)}
.basecard .ico{font-size:26px;width:40px;text-align:center;flex:none}
.basecard .meta h3{font-size:17px;font-weight:700}
.basecard .meta p{color:var(--ink-soft);font-size:13px;margin-top:2px;letter-spacing:.3px}

/* 學習卡 回扣地基 chip */
.chips{margin-top:11px;display:flex;flex-wrap:wrap;align-items:center;gap:7px;font-size:12.5px;color:var(--ink-soft)}
.chip{border:1px solid var(--gold);background:#fff;color:var(--gold-deep);border-radius:999px;
  padding:4px 12px;font-size:13px;font-weight:700;cursor:pointer;font-family:inherit}
.chip:active{transform:scale(.95)}

/* 助詞/動詞 列表 */
.base-list{display:flex;flex-direction:column;gap:11px;margin-top:14px}
.base-item{display:flex;align-items:center;gap:13px;background:var(--card);border:1px solid var(--line);
  border-radius:14px;padding:15px 16px;cursor:pointer;font-family:inherit;text-align:left;transition:transform .1s}
.base-item:active{transform:scale(.99)}
.base-item .bt{font-size:20px;font-weight:800;color:var(--gold-deep);min-width:62px;flex:none}
.base-item .bl{font-size:14.5px;color:var(--ink)}

/* 地基詳解 */
.base-detail{background:var(--card);border:1px solid var(--line);border-radius:20px;box-shadow:var(--shadow);
  padding:22px 20px;margin-bottom:18px}
.base-detail h2{font-size:21px;font-weight:800}
.base-detail .rule{color:#544f46;font-size:15px;margin-top:10px;line-height:1.65}
.base-detail a.vlink{display:inline-block;margin-top:12px;color:var(--gold-deep);font-weight:700;
  text-decoration:none;font-size:13px}
.base-detail a.vlink::before{content:"📺 "}
.ex-head{font-size:13px;color:var(--gold-deep);font-weight:700;margin:4px 2px 11px}
.ex-list{display:flex;flex-direction:column;gap:11px}
.ex-card{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:14px 16px}
.ex-top{display:flex;align-items:center;gap:10px}
.ex-jp{font-size:20px;font-weight:700;flex:1;line-height:1.4}
.ex-kana{font-size:14px;color:var(--ink-soft);margin-top:5px}
.ex-romaji{font-size:13px;color:var(--gold-deep);font-style:italic;margin-top:2px}
.ex-zh{font-size:15px;margin-top:7px;font-weight:600}
.speak.mini{flex:none;padding:8px 13px;font-size:15px;margin:0}

/* 五十音 */
.kana-menu{display:flex;flex-direction:column;gap:11px;margin-top:14px}
.kana-grp{display:flex;flex-direction:column;align-items:flex-start;gap:3px;background:var(--card);
  border:1px solid var(--line);border-radius:14px;padding:15px 16px;cursor:pointer;font-family:inherit;
  text-align:left;transition:transform .1s}
.kana-grp:active{transform:scale(.99)}
.kg-set{font-size:11px;color:var(--gold-deep);font-weight:700;letter-spacing:1px}
.kg-name{font-size:17px;font-weight:700}
.kg-note{font-size:12.5px;color:var(--ink-soft);line-height:1.5}
.kana-flash{background:var(--card);border:1px solid var(--line);border-radius:24px;box-shadow:var(--shadow);
  padding:34px 22px 28px;text-align:center;margin-bottom:16px}
.kana-flash .kchar{font-size:88px;font-weight:700;line-height:1;letter-spacing:2px}
.kana-flash .krom{font-size:22px;color:var(--gold-deep);font-style:italic;margin-top:14px;letter-spacing:1px}
.kana-ex{display:flex;flex-direction:column;gap:8px;margin:16px 0 4px}
.kex{display:flex;align-items:center;gap:9px;background:#fbf8f1;border:1px solid var(--line);border-radius:12px;
  padding:10px 13px;cursor:pointer;font-family:inherit;text-align:left}
.kex b{font-size:17px;font-weight:700}
.kex span{color:var(--gold-deep);font-style:italic;font-size:13px}
.kex i{margin-left:auto;color:var(--ink-soft);font-size:13.5px;font-style:normal}
.btn.quiz{background:#fff;color:var(--gold-deep);border:1.5px dashed var(--gold);margin-top:12px;font-size:15px}
.kana-opts{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.kana-opts .option{text-align:center;font-size:30px;font-weight:700;padding:20px}

/* 閱讀辨識 */
.read-cat{display:inline-block;font-size:12px;color:var(--gold-deep);font-weight:700;background:#fbf8f1;
  border:1px solid var(--line);border-radius:999px;padding:4px 12px;margin-bottom:12px}
.read-sign{font-size:46px;font-weight:800;letter-spacing:3px;line-height:1.3}

/* ===== v3:進度・複習・互動 ===== */
/* 羅馬拼音開關(漸隱學習法) */
.romaji-toggle{margin-left:auto;border:1px solid var(--line);background:var(--card);color:var(--ink-soft);
  border-radius:999px;padding:7px 13px;font-size:12.5px;cursor:pointer;font-weight:700;font-family:inherit;
  letter-spacing:.3px;opacity:.65;transition:opacity .2s}
.romaji-toggle.on{border-color:var(--gold);color:var(--gold-deep);opacity:1}
body.no-romaji .romaji, body.no-romaji .ex-romaji, body.no-romaji .shadow-romaji,
body.no-romaji .krom{display:none}

/* 繼續上次 / 錯題複習 入口卡 */
.resume{display:flex;align-items:center;gap:13px;width:100%;background:linear-gradient(135deg,#3a362e,#55503f);
  color:#fff;border:0;border-radius:var(--radius);padding:15px 17px;margin-bottom:12px;cursor:pointer;
  font-family:inherit;text-align:left;box-shadow:var(--shadow);transition:transform .12s}
.resume:active{transform:scale(.985)}
.resume .r-ico{font-size:24px;flex:none}
.resume .r-meta{flex:1;min-width:0}
.resume .r-meta b{display:block;font-size:16px;font-weight:700}
.resume .r-meta i{display:block;font-style:normal;font-size:12.5px;opacity:.75;margin-top:2px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.resume .r-go{font-size:18px;color:var(--gold);flex:none}
.resume.wrongdeck{background:linear-gradient(135deg,#6c4a3c,#8a5f4a)}

/* 課程卡迷你進度條 */
.mini-prog{height:4px;background:var(--line);border-radius:999px;overflow:hidden;margin-top:8px;max-width:150px}
.mini-prog > i{display:block;height:100%;background:linear-gradient(90deg,var(--gold),var(--gold-deep))}

/* 假名組測驗成績 badge */
.kg-best{margin-left:8px;font-size:12px;color:var(--ink-soft);border:1px solid var(--line);
  border-radius:999px;padding:2px 9px;font-weight:700;vertical-align:2px}
.kg-best.full{color:var(--good);border-color:var(--good)}

/* 五十音總表 */
.chart-row{display:flex;gap:11px;margin-bottom:15px}
.chart-btn{flex:1;border:1.5px dashed var(--gold);background:#fff;color:var(--gold-deep);border-radius:14px;
  padding:13px;font-size:14.5px;font-weight:700;cursor:pointer;font-family:inherit;transition:transform .1s}
.chart-btn:active{transform:scale(.97)}
.chart-grp{margin-bottom:18px}
.chart-grp-name{font-size:13px;color:var(--gold-deep);font-weight:700;margin:0 2px 8px}
.chart-line{display:grid;grid-template-columns:repeat(5,1fr);gap:7px;margin-bottom:7px}
.chart-cell{display:flex;flex-direction:column;align-items:center;gap:1px;background:var(--card);
  border:1px solid var(--line);border-radius:11px;padding:9px 2px 7px;cursor:pointer;font-family:inherit;
  transition:transform .1s,border-color .15s,background .15s}
.chart-cell:active{transform:scale(.94)}
.chart-cell.hit{border-color:var(--gold);background:#fbf8f1}
.chart-cell b{font-size:21px;font-weight:700;line-height:1.2}
.chart-cell span{font-size:10.5px;color:var(--ink-soft);font-style:italic}
