/* =========================================================
   追加スタイル — リスニング(P1-4)・単語ページ共通
   ========================================================= */

/* ---- numbered question nav (snav拡張) ---- */
.snav .ck { color: var(--correct); font-weight: 800; margin-left: .3em; }
.snav.on .ck { color: #c9f0d2; }
.snav .ng { color: var(--wrong); font-weight: 800; margin-left: .3em; }
.snav.on .ng { color: #ffd9d4; }

/* ---- audio play button ---- */
.play-btn {
  display: inline-flex; align-items: center; gap: .6em;
  font-family: var(--jp); font-weight: 800; font-size: 15px; cursor: pointer;
  background: var(--brown); color: #fff; border: none;
  border-radius: var(--r-pill); padding: .75em 1.6em;
  box-shadow: var(--shadow-sm); transition: transform .15s, background .15s;
}
.play-btn:hover { transform: translateY(-1px); }
.play-btn.playing { background: var(--wrong); }
.play-btn .pb-ico { font-size: .85em; }
.audio-row { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; margin-bottom: 18px; }
.audio-note { font-size: 12.5px; color: var(--muted); }

/* ---- Part 1 photo ---- */
.p1-photo {
  width: 100%; max-width: 560px; aspect-ratio: 4 / 3; object-fit: cover;
  border-radius: var(--r-sm); display: block; margin: 0 auto 20px;
  box-shadow: var(--shadow-sm); background: var(--paper-2);
}

/* ---- script (対訳) rows ---- */
.script-box { margin-top: 22px; border-top: 1.5px dashed var(--line); padding-top: 18px; }
.script-title { font-family: var(--jp); font-weight: 800; color: var(--ink); font-size: 16px; margin: 0 0 12px; }
.scr-row { display: flex; gap: 12px; padding: 9px 0; border-bottom: 1px solid var(--line); }
.scr-row:last-child { border-bottom: none; }
.scr-spk {
  flex: 0 0 34px; height: 34px; border-radius: 50%; display: grid; place-items: center;
  font-family: var(--en); font-weight: 800; font-size: 13px; color: #fff;
}
.scr-spk.m { background: var(--role-s); }
.scr-spk.w { background: var(--role-v); }
.scr-spk.n { background: var(--camel); }
.scr-body { flex: 1 1 auto; }
.scr-en { font-family: var(--en); font-weight: 600; font-size: 16px; color: #43301f; line-height: 1.6; }
.scr-jp { font-size: 13.5px; color: var(--ink-2); margin-top: 2px; }
.scr-key { background: linear-gradient(transparent 58%, var(--peach) 58%, var(--peach) 92%, transparent 92%); }

/* ---- statement list (Part 1/2 choices read aloud) ---- */
.locked-note {
  display: flex; align-items: center; gap: 10px; margin: 14px 0 0;
  font-size: 13.5px; color: var(--muted);
}

/* ---- vocab ---- */
.vday {
  display: inline-flex; align-items: center; gap: .5em;
  font-family: var(--jp); font-weight: 800; font-size: 13px;
  background: var(--peach-2); color: var(--brown); border-radius: var(--r-pill); padding: .45em 1.2em;
}
.vlevel-tabs { display: flex; gap: 8px; flex-wrap: wrap; margin: 0 0 16px; }
.vword-list { display: flex; flex-direction: column; gap: 12px; }
.vword { padding: 18px 20px; }
.vw-head { display: flex; align-items: baseline; gap: 12px; flex-wrap: wrap; }
.vw-no { font-family: var(--en); font-weight: 800; font-size: 12px; color: var(--camel); }
.vw-en { font-family: var(--en); font-weight: 800; font-size: 21px; color: var(--ink); }
.vw-pos { font-size: 11.5px; font-weight: 700; color: var(--ink-2); background: var(--paper-2); border-radius: var(--r-pill); padding: .25em .8em; }
.vw-jp { font-weight: 700; color: var(--ink-2); font-size: 15px; }
.vw-listen {
  margin-left: auto; border: 1.5px solid var(--camel-soft); background: var(--card); color: var(--ink-2);
  border-radius: var(--r-pill); font-family: var(--jp); font-weight: 700; font-size: 12.5px;
  padding: .35em 1em; cursor: pointer; transition: background .15s;
}
.vw-listen:hover { background: var(--peach-2); }
.vw-ex { margin: 8px 0 0; font-family: var(--en); font-size: 14.5px; color: #43301f; line-height: 1.7; }
.vw-ex b { color: var(--brown); }
.vw-exjp { margin: 2px 0 0; font-size: 13px; color: var(--muted); }
.vword.locked { opacity: .55; }
.vword.locked .vw-en { filter: blur(5px); }
.vword.locked .vw-ex, .vword.locked .vw-exjp, .vword.locked .vw-jp { filter: blur(4px); }
.vw-lock {
  margin-left: auto; font-size: 12.5px; font-weight: 700; color: var(--muted);
}
.unlock-banner {
  display: flex; align-items: center; gap: 12px; flex-wrap: wrap;
  background: var(--peach-2); border-radius: var(--r-sm); padding: 14px 18px; margin: 0 0 18px;
  font-size: 14px; font-weight: 700; color: var(--ink);
}
.unlock-banner .ub-big { font-family: var(--en); font-weight: 800; font-size: 20px; color: var(--brown); }

/* ---- set header (P3/P4/P7) ---- */
.set-meta { display: flex; gap: 8px; flex-wrap: wrap; margin: 0 0 14px; }
.set-chip {
  font-family: var(--jp); font-size: 12px; font-weight: 700; color: var(--ink-2);
  background: var(--paper-2); border-radius: var(--r-pill); padding: .35em 1em;
}

/* ---- vocab flashcard ---- */
.fc-note { font-size: 14px; color: var(--ink-2); line-height: 1.9; margin: 0 0 14px; }
.fc-bar {
  display: flex; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: wrap;
  background: var(--peach-2); border-radius: var(--r-lg, 20px); padding: 14px 20px; margin-bottom: 16px;
}
.fc-prog { font-family: var(--jp); font-weight: 800; font-size: 15px; color: var(--ink); }
.fc-got { color: var(--correct); }
.fc-nav { display: flex; gap: 8px; }
.fnav-btn.primary { background: var(--brown); color: #fff; border-color: var(--brown); }
.fnav-btn.primary:hover:not(:disabled) { background: var(--brown); opacity: .88; }
.fc-card { cursor: pointer; padding: clamp(22px, 4vw, 34px); min-height: 420px; user-select: none; }
.fc-top { display: flex; justify-content: space-between; align-items: center; gap: 10px; margin-bottom: 8px; }
.fc-tag { font-family: var(--en); font-weight: 700; font-size: 13px; color: var(--camel); margin-right: 8px; }
.fc-pos { font-size: 11.5px; font-weight: 700; color: var(--brown); background: var(--peach-2); border-radius: var(--r-pill); padding: .3em .9em; }
.fc-hint { font-size: 12.5px; color: var(--muted); font-weight: 700; }
.fc-front { text-align: center; padding: 40px 10px 30px; }
.fc-word { font-family: var(--en); font-weight: 800; font-size: clamp(40px, 7vw, 64px); color: var(--brown); margin: 0 0 6px; line-height: 1.15; word-break: break-word; }
.fc-ipa { font-family: var(--en); font-style: italic; color: var(--muted); font-size: 17px; margin: 0 0 22px; }
.fc-say { font-size: 14px; padding: .6em 1.5em; }
.fc-say.sm { font-size: 12.5px; padding: .45em 1.2em; vertical-align: middle; }
.fc-cap { font-size: 13px; color: var(--muted); margin: 26px 0 0; }
.fc-back { padding: 6px 4px 0; }
.fc-jp { font-family: var(--jp); font-weight: 900; font-size: clamp(28px, 4.5vw, 40px); color: var(--ink); margin: 8px 0 14px; display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.fc-desc {
  background: var(--peach-2); border-radius: 12px; padding: 14px 18px;
  font-size: 14.5px; font-weight: 600; color: var(--ink); line-height: 1.85; margin-bottom: 18px;
}
.fc-sec { font-family: var(--jp); font-weight: 800; font-size: 12.5px; color: var(--camel); letter-spacing: .06em; margin: 0 0 8px; }
.fc-col { font-family: var(--en); font-weight: 800; font-size: 16.5px; color: #43301f; margin: 0 0 8px; }
.fc-col span { font-family: var(--jp); font-weight: 600; font-size: 13px; color: var(--ink-2); }
.fc-rel { border-top: 1.5px solid var(--line); margin-top: 14px; padding-top: 12px; display: flex; gap: 18px; flex-wrap: wrap; font-family: var(--en); font-weight: 700; font-size: 15px; }
.fc-syn { color: #2e9e57; }
.fc-ant { color: #c94f4f; }
.fc-foot { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-top: 16px; flex-wrap: wrap; }
.fc-dots { display: flex; gap: 6px; flex-wrap: wrap; }
.fc-dots i { width: 9px; height: 9px; border-radius: 50%; background: var(--line); }
.fc-dots i.on { background: var(--brown); }
.fc-dots i.done { background: var(--correct); }
.fc-gotbtn {
  font-family: var(--jp); font-weight: 800; font-size: 13.5px; cursor: pointer;
  border: 1.5px solid var(--camel-soft); background: var(--card); color: var(--ink-2);
  border-radius: var(--r-pill); padding: .6em 1.6em; transition: all .15s;
}
.fc-gotbtn:hover { background: var(--peach-2); }
.fc-gotbtn.on { background: var(--correct-bg); border-color: var(--correct); color: #2c7a44; }

/* ---- next/prev ---- */
.foot-nav { display: flex; justify-content: space-between; gap: 10px; margin-top: 22px; }
.fnav-btn {
  font-family: var(--jp); font-weight: 700; font-size: 14.5px; cursor: pointer;
  border: 1.5px solid var(--camel-soft); background: var(--card); color: var(--ink-2);
  border-radius: var(--r-pill); padding: .65em 1.5em; transition: all .15s;
}
.fnav-btn:hover:not(:disabled) { background: var(--peach-2); }
.fnav-btn:disabled { opacity: .35; cursor: default; }

/* ===== モバイル改善（タスク2A/2C｜モバイルのみ・追記・PC非変更） ===== */
@media (max-width: 600px){
  /* 2A: ヘッダーのPartタブを折返して全表示（横スクロールで切れるのを解消） */
  .part-nav{ flex-wrap: wrap; overflow-x: visible; }
  .part-nav .ppill{ font-size: 12px; padding: .38em .8em; }
}
@media (max-width: 560px){
  /* 2C: 問題番号ボタン(101〜等)をモバイルでコンパクトに */
  .sentence-nav{ gap: 6px; }
  .snav{ font-size: 12.5px; padding: .35em .7em; }
}

/* ===== フッターの法務リンク（特商法対応・追記） ===== */
.site-foot .foot-legal{ display:flex; flex-wrap:wrap; gap:8px 14px; font-size:12.5px; }
.site-foot .foot-legal a{ color:var(--ink-2); font-weight:700; text-decoration:none; }
.site-foot .foot-legal a:hover{ color:var(--brown); }
/* 商標・非提携の注記（全フッター共通・小さめミュート・独立行） */
.site-foot .foot-tm{ width:100%; flex-basis:100%; margin:12px 0 0; padding:0; font-size:11px; line-height:1.7; color:var(--muted,#9b8a76); text-align:center; font-weight:500; }

/* ===== nav-pager — ナビ ページ送り（番号ピル型/セットカード型 共通） ===== */
.nav-total{ font-family:var(--jp); font-weight:800; font-size:13.5px; color:var(--ink-2); margin:0 0 10px; }
.nav-total em{ font-style:normal; font-family:var(--en); font-weight:800; color:var(--brown); }
.nav-pager{ display:flex; align-items:center; justify-content:center; flex-wrap:wrap; gap:8px 10px; margin:14px 0 4px; }
.pager-btn{ font-family:var(--jp); font-weight:800; font-size:13.5px; cursor:pointer; background:var(--card); color:var(--ink-2); border:1.5px solid var(--line); border-radius:var(--r-pill); padding:.5em 1.2em; transition:all .16s; white-space:nowrap; }
.pager-btn:hover:not(:disabled){ border-color:var(--camel); }
.pager-btn:disabled{ opacity:.4; cursor:default; }
.pager-info{ font-family:var(--en); font-weight:800; font-size:13.5px; color:var(--ink-2); min-width:52px; text-align:center; }
.pager-dots{ display:flex; align-items:center; gap:7px; }
.pager-dot{ width:9px; height:9px; border-radius:50%; padding:0; cursor:pointer; background:var(--camel-soft); border:none; transition:all .16s; }
.pager-dot:hover{ background:var(--camel); }
.pager-dot.on{ background:var(--brown); transform:scale(1.25); }
/* 番号ピル：1〜3桁で幅を揃えて等間隔に整列 */
.num-nav .snav{ min-width:52px; display:inline-flex; align-items:center; justify-content:center; box-sizing:border-box; }
/* セットカード：等幅グリッドで整列・長文ラベルは2行折返し（省略記号なし） */
.set-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(150px,1fr)); gap:10px; margin:0 0 4px; }
.set-grid .pnav-t{ white-space:normal; word-break:break-word; }
@media (max-width:480px){
  .nav-pager{ gap:8px; }
  .pager-dots{ display:none; }
  .pager-btn{ padding:.5em 1.05em; font-size:13px; }
  .set-grid{ grid-template-columns:1fr; }
}
