/* =========================================================================
 *  多読アプリ  -  スタイル（モバイルファースト）
 * ====================================================================== */
:root{
  --bg:#0f1226; --bg2:#171a33; --card:#1d2142; --card2:#252a52;
  --text:#eef1ff; --muted:#9aa3cf; --line:#2c3160;
  --accent:#7c8cff; --accent2:#22d3ee; --good:#34d399; --warn:#fb923c;
  --reader-bg:#0f1226; --reader-text:#eef1ff; --reader-font:'Georgia',serif;
  --reader-size:20px; --reader-lh:2.0; --hl:#ffd34d; --hl-text:#1a1a1a;
  --safe-b:env(safe-area-inset-bottom,0px);
}
[data-theme="light"]{
  --bg:#f4f6ff; --bg2:#ffffff; --card:#ffffff; --card2:#eef1ff;
  --text:#1a1f3c; --muted:#5b648f; --line:#dfe3f5;
  --reader-bg:#fbfcff; --reader-text:#1a1f3c; --hl:#ffe27a; --hl-text:#1a1a1a;
}
[data-theme="sepia"]{
  --bg:#efe6d3; --bg2:#f6efe0; --card:#f7f0e1; --card2:#efe4cc;
  --text:#3b2f1c; --muted:#8a7a5c; --line:#e0d2b3;
  --reader-bg:#f4ecd8; --reader-text:#3b2f1c; --hl:#e8b84b; --hl-text:#1a1a1a;
}

*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;padding:0}
body{
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Hiragino Kaku Gothic ProN","Noto Sans JP",sans-serif;
  background:linear-gradient(180deg,var(--bg),var(--bg2));
  color:var(--text); min-height:100dvh; line-height:1.6;
  overflow-x:hidden;
}
.hidden{display:none!important}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}

/* ===== トップバー ===== */
.topbar{
  position:sticky;top:0;z-index:40;display:flex;align-items:center;gap:10px;
  padding:14px 16px;background:rgba(15,18,38,.82);backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
}
[data-theme="light"] .topbar{background:rgba(255,255,255,.85)}
[data-theme="sepia"] .topbar{background:rgba(246,239,224,.9)}
.brand{display:flex;align-items:center;gap:9px;font-weight:800;font-size:18px;letter-spacing:.3px}
.brand .logo{font-size:22px}
.brand small{color:var(--muted);font-weight:600;font-size:11px}
.topbar .spacer{flex:1}
.icon-btn{width:40px;height:40px;border-radius:12px;display:grid;place-items:center;
  font-size:18px;background:var(--card);border:1px solid var(--line)}
.icon-btn:active{transform:scale(.92)}

/* ===== 画面共通 ===== */
.view{padding:16px 16px 100px;max-width:760px;margin:0 auto;animation:fade .3s ease}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.section-title{font-size:14px;color:var(--muted);font-weight:700;margin:18px 4px 10px;text-transform:uppercase;letter-spacing:.6px}
.hero{
  background:linear-gradient(135deg,#7c8cff22,#22d3ee18);border:1px solid var(--line);
  border-radius:20px;padding:18px 18px 20px;margin-bottom:8px
}
.hero h1{margin:0 0 4px;font-size:22px}
.hero p{margin:0;color:var(--muted);font-size:13px}
.hero .stats-row{display:flex;gap:14px;margin-top:14px}
.hero .stat{flex:1;background:var(--card);border:1px solid var(--line);border-radius:14px;padding:10px;text-align:center}
.hero .stat b{display:block;font-size:20px;color:var(--accent2)}
.hero .stat span{font-size:11px;color:var(--muted)}

/* ===== レベルカード ===== */
.levels{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.level-card{
  background:var(--card);border:1px solid var(--line);border-radius:16px;padding:14px;
  text-align:left;position:relative;overflow:hidden;transition:transform .12s
}
.level-card:active{transform:scale(.97)}
.level-card .lv-badge{display:inline-block;font-size:11px;font-weight:800;color:#0b0e22;
  padding:3px 9px;border-radius:999px;margin-bottom:8px}
.level-card h3{margin:0;font-size:15px}
.level-card .jp{font-size:12px;color:var(--muted);margin:2px 0 6px}
.level-card .yl{font-size:11px;color:var(--accent2);font-weight:700}
.level-card .count{position:absolute;top:12px;right:12px;font-size:11px;color:var(--muted)}

/* ===== 本リスト ===== */
.search-bar{display:flex;gap:8px;margin-bottom:6px}
.search-bar input{flex:1;padding:12px 14px;border-radius:12px;background:var(--card);
  border:1px solid var(--line);color:var(--text);font-size:14px;outline:none}
.book{
  display:flex;gap:12px;align-items:center;background:var(--card);border:1px solid var(--line);
  border-radius:16px;padding:12px;margin-bottom:10px;transition:transform .12s
}
.book:active{transform:scale(.985)}
.book .cover{width:54px;height:54px;border-radius:13px;display:grid;place-items:center;font-size:28px;
  background:var(--card2);flex:none}
.book .info{flex:1;min-width:0}
.book .info h4{margin:0;font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.book .meta{font-size:12px;color:var(--muted);margin-top:3px}
.book .tag{display:inline-block;font-size:10px;padding:2px 7px;border-radius:999px;background:var(--card2);
  color:var(--muted);margin-right:5px}
.book .prog{height:5px;border-radius:999px;background:var(--card2);margin-top:7px;overflow:hidden}
.book .prog i{display:block;height:100%;background:linear-gradient(90deg,var(--accent),var(--accent2))}
.empty{color:var(--muted);text-align:center;padding:40px 10px;font-size:14px}

/* ===== リーダー ===== */
#view-reader{padding:0;max-width:none}
#reader-scroll{height:100dvh;overflow-y:auto;-webkit-overflow-scrolling:touch}
.reader-top{position:sticky;top:0;z-index:30;display:flex;align-items:center;gap:8px;
  padding:12px 14px;background:rgba(15,18,38,.85);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
[data-theme="light"] .reader-top{background:rgba(255,255,255,.88)}
[data-theme="sepia"] .reader-top{background:rgba(246,239,224,.9)}
.reader-top .title{flex:1;min-width:0;font-weight:700;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.reader-scroll{background:var(--reader-bg)}
.reader-body{
  max-width:720px;margin:0 auto;padding:22px 22px 200px;
  font-family:var(--reader-font);font-size:var(--reader-size);line-height:var(--reader-lh);
  color:var(--reader-text)
}
.reader-body .src{font-size:12px;color:var(--muted);margin:-6px 0 20px;font-family:sans-serif}
.reader-body p{margin:0 0 1.1em}
.w{cursor:pointer;border-radius:4px;padding:0 1px;transition:background .1s}
.w:hover{background:var(--card2)}
.w.spoken{background:var(--hl);color:var(--hl-text)}
.w.saved{box-shadow:inset 0 -2px 0 var(--good)}

/* リーダー操作バー（下） */
.reader-bar{
  position:fixed;left:0;right:0;bottom:0;z-index:35;
  padding:10px 14px calc(10px + var(--safe-b));
  background:rgba(15,18,38,.92);backdrop-filter:blur(14px);border-top:1px solid var(--line)
}
[data-theme="light"] .reader-bar{background:rgba(255,255,255,.94)}
[data-theme="sepia"] .reader-bar{background:rgba(246,239,224,.95)}
.reader-bar .row{display:flex;align-items:center;gap:10px;max-width:720px;margin:0 auto}
.play-btn{width:56px;height:56px;border-radius:50%;flex:none;display:grid;place-items:center;font-size:24px;
  background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;box-shadow:0 6px 18px #7c8cff55}
.play-btn:active{transform:scale(.92)}
.ctrl{width:44px;height:44px;border-radius:12px;flex:none;display:grid;place-items:center;font-size:17px;
  background:var(--card);border:1px solid var(--line)}
.speed-pill{padding:8px 12px;border-radius:999px;background:var(--card);border:1px solid var(--line);
  font-size:13px;font-weight:700;white-space:nowrap}
.reader-bar .read-prog{height:4px;border-radius:999px;background:var(--card2);margin:0 auto 10px;max-width:720px;overflow:hidden}
.reader-bar .read-prog i{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--accent),var(--accent2))}

/* ===== 単語ポップアップ ===== */
.wordpop{
  position:fixed;z-index:60;background:var(--card);border:1px solid var(--line);
  border-radius:16px;padding:14px 16px;box-shadow:0 16px 40px #0008;max-width:300px;
  animation:pop .14s ease
}
@keyframes pop{from{opacity:0;transform:scale(.9)}to{opacity:1;transform:none}}
.wordpop .wp-head{display:flex;align-items:center;gap:8px;margin-bottom:6px}
.wordpop .wp-word{font-size:19px;font-weight:800}
.wordpop .wp-say{margin-left:auto;width:34px;height:34px;border-radius:10px;background:var(--card2);
  display:grid;place-items:center;font-size:16px}
.wordpop .wp-jp{font-size:15px;color:var(--accent2);font-weight:700;margin-bottom:4px}
.wordpop .wp-en{font-size:13px;color:var(--muted);line-height:1.5}
.wordpop .wp-actions{display:flex;gap:8px;margin-top:10px}
.wordpop .wp-actions button{flex:1;padding:8px;border-radius:10px;font-size:12px;font-weight:700;
  background:var(--card2);border:1px solid var(--line)}
.wordpop .wp-actions .save{background:var(--good);color:#04231a;border:none}

/* ===== 下タブ ===== */
.tabbar{
  position:fixed;left:0;right:0;bottom:0;z-index:50;display:flex;
  padding:6px 8px calc(6px + var(--safe-b));
  background:rgba(15,18,38,.94);backdrop-filter:blur(14px);border-top:1px solid var(--line)
}
[data-theme="light"] .tabbar{background:rgba(255,255,255,.95)}
[data-theme="sepia"] .tabbar{background:rgba(246,239,224,.96)}
.tabbar button{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 0;
  font-size:10px;color:var(--muted);font-weight:700}
.tabbar button .ti{font-size:21px}
.tabbar button.active{color:var(--accent)}

/* ===== モーダル/シート ===== */
.sheet-mask{position:fixed;inset:0;z-index:55;background:#0009;backdrop-filter:blur(2px);
  display:flex;align-items:flex-end;justify-content:center;animation:fade .2s}
.sheet{width:100%;max-width:520px;background:var(--bg2);border:1px solid var(--line);
  border-radius:22px 22px 0 0;padding:18px 18px calc(24px + var(--safe-b));max-height:86dvh;overflow:auto;
  animation:slideup .25s ease}
@keyframes slideup{from{transform:translateY(100%)}to{transform:none}}
.sheet h3{margin:0 0 14px;font-size:17px}
.sheet .close{position:absolute}
.field{margin-bottom:16px}
.field label{display:block;font-size:13px;color:var(--muted);font-weight:700;margin-bottom:7px}
.seg{display:flex;gap:6px;flex-wrap:wrap}
.seg button{padding:8px 12px;border-radius:10px;background:var(--card);border:1px solid var(--line);font-size:13px;font-weight:700}
.seg button.on{background:var(--accent);color:#fff;border-color:var(--accent)}
.range{width:100%}
select,.txt{width:100%;padding:11px 12px;border-radius:11px;background:var(--card);border:1px solid var(--line);
  color:var(--text);font-size:14px;outline:none}
.btn-primary{width:100%;padding:13px;border-radius:13px;font-weight:800;font-size:15px;
  background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;margin-top:6px}
.btn-primary:active{transform:scale(.98)}
.note{font-size:12px;color:var(--muted);line-height:1.6;margin-top:8px}

/* ===== 単語帳 / 記録 ===== */
.vocab-item{display:flex;align-items:center;gap:12px;background:var(--card);border:1px solid var(--line);
  border-radius:14px;padding:12px;margin-bottom:9px}
.vocab-item .vw{font-weight:800;font-size:16px}
.vocab-item .vj{font-size:13px;color:var(--accent2)}
.vocab-item .vsay{margin-left:auto;width:36px;height:36px;border-radius:10px;background:var(--card2);display:grid;place-items:center}
.vocab-item .vdel{width:36px;height:36px;border-radius:10px;background:var(--card2);display:grid;place-items:center;color:#ff7a7a}
.badges{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}
.badge{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:14px 8px;text-align:center}
.badge .bi{font-size:30px;filter:grayscale(1);opacity:.35}
.badge.got .bi{filter:none;opacity:1}
.badge .bn{font-size:11px;margin-top:6px;font-weight:700}
.badge .bd{font-size:10px;color:var(--muted)}

/* フラッシュカード */
.flash{background:var(--card);border:1px solid var(--line);border-radius:20px;padding:40px 20px;text-align:center;
  min-height:200px;display:flex;flex-direction:column;justify-content:center;cursor:pointer;margin-bottom:14px}
.flash .fw{font-size:30px;font-weight:800}
.flash .fj{font-size:20px;color:var(--accent2);margin-top:14px}
.flash .hint{font-size:12px;color:var(--muted);margin-top:18px}
.flash-row{display:flex;gap:10px}
.flash-row button{flex:1;padding:13px;border-radius:13px;font-weight:800;border:1px solid var(--line);background:var(--card)}

/* トースト */
.toast{position:fixed;left:50%;bottom:90px;transform:translateX(-50%);z-index:80;
  background:#000c;color:#fff;padding:10px 18px;border-radius:999px;font-size:13px;font-weight:700;
  animation:fade .2s}
@media(min-width:560px){.levels{grid-template-columns:1fr 1fr 1fr}}
