:root{--bg: #0f1115;--surface: #171b22;--surface-2: #20262f;--border: #2a313c;--text: #e8eaed;--muted: #98a0ab;--accent: #4cc2ff;--accent-ink: #06222e;--accent-dim: #173243;--flag: #ffb454;--flag-ink: #2e1d05;--radius: 14px}*{box-sizing:border-box}html,body{margin:0;padding:0;background:var(--bg);color:var(--text);overscroll-behavior-y:none}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Hiragino Sans,Noto Sans JP,sans-serif;-webkit-font-smoothing:antialiased;font-size:16px}#root,.app{height:100dvh}.app{display:flex;flex-direction:column;max-width:640px;margin:0 auto}button{font:inherit;color:inherit;background:none;border:none;padding:0;cursor:pointer;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.screen{display:flex;flex-direction:column;height:100%;min-height:0}.topbar{display:flex;align-items:center;gap:6px;padding:calc(env(safe-area-inset-top) + 10px) 12px 8px;flex-shrink:0}.topbar-title{flex:1;margin:0;font-size:17px;font-weight:650;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.icon-btn{min-width:44px;min-height:44px;display:grid;place-items:center;border-radius:12px;font-size:22px;color:var(--muted);flex-shrink:0}.icon-btn:active{background:var(--surface-2)}.synthesis-btn{color:var(--accent);font-size:18px;border:1px solid var(--border)}.center-state{flex:1;display:grid;place-items:center;color:var(--muted);padding:24px;text-align:center;line-height:1.5}.state-detail{font-size:13px;opacity:.8;overflow-wrap:anywhere}.primary-btn{min-height:50px;padding:0 22px;border-radius:12px;background:var(--accent);color:var(--accent-ink);font-weight:650;font-size:16px;margin-top:12px}.primary-btn:active{filter:brightness(1.15)}.episode-list{flex:1;overflow-y:auto;padding:4px 12px calc(env(safe-area-inset-bottom) + 16px);display:flex;flex-direction:column;gap:10px}.episode-card{display:flex;align-items:stretch;width:100%;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);min-height:72px}.episode-open{flex:1;min-width:0;display:flex;flex-direction:column;justify-content:center;gap:6px;text-align:left;padding:16px;border-radius:var(--radius)}.episode-open:active{background:var(--surface-2)}.dl-btn{align-self:center;min-width:44px;min-height:44px;margin-right:10px;display:grid;place-items:center;border-radius:12px;border:1px solid var(--border);color:var(--muted);font-size:18px;flex-shrink:0}.dl-btn:active{background:var(--surface-2)}.dl-btn.downloaded{color:var(--accent);border-color:var(--accent-dim);background:var(--accent-dim)}.dl-btn.downloading{color:var(--accent);animation:dl-pulse 1s ease-in-out infinite}@keyframes dl-pulse{0%,to{opacity:1}50%{opacity:.35}}.offline-hint{margin:2px 4px 0;color:var(--muted);font-size:13px;text-align:center}.linklike.inline{min-height:0;padding:0}.episode-title{font-size:16px;font-weight:600;line-height:1.4}.episode-meta{display:flex;align-items:center;gap:10px;color:var(--muted);font-size:13px}.lang-chip{text-transform:uppercase;font-size:11px;font-weight:700;letter-spacing:.06em;color:var(--accent);background:var(--accent-dim);border-radius:6px;padding:2px 6px}.transcript{flex:1;overflow-y:auto;min-height:0;padding:4px 12px 16px}.transcript-hint{color:var(--muted);font-size:12px;text-align:center;margin:4px 0 10px}.transcript-tools{display:flex;gap:8px;padding:6px 0 2px;flex-wrap:wrap;justify-content:center}.chip{min-height:36px;padding:0 14px;border-radius:10px;border:1px solid var(--border);color:var(--muted);font-size:13px;font-weight:600}.chip.on{color:var(--accent);border-color:var(--accent-dim);background:var(--accent-dim)}.chip:active{filter:brightness(1.2)}.line-text rt{font-size:.6em;color:var(--muted);font-weight:500;line-height:1}.line-text .w-new{color:var(--accent)}.line-text .w-learning{color:var(--flag)}.line-text .w-known{color:var(--muted)}.tok{display:inline;cursor:pointer;border-radius:4px}.tok:active{background:var(--surface-2)}.line-time{cursor:pointer;text-align:left}.line-time:active{color:var(--accent)}.def-backdrop{position:fixed;inset:0;z-index:30;background:#0000008c}.def-sheet{position:fixed;left:0;right:0;bottom:0;z-index:31;max-width:640px;margin:0 auto;max-height:70vh;overflow-y:auto;background:var(--surface);border-radius:18px 18px 0 0;border:1px solid var(--border);border-bottom:none;padding:14px 16px calc(env(safe-area-inset-bottom) + 16px)}.def-head{display:flex;align-items:center;gap:10px;position:sticky;top:0;background:var(--surface);padding-bottom:6px}.def-term{flex:1;font-size:24px;font-weight:650;overflow-wrap:anywhere}.def-status{color:var(--muted);font-size:14px;margin:6px 0}.def-entry{border-top:1px solid var(--border);padding:10px 0}.def-forms{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap;margin-bottom:4px}.def-kanji{font-size:17px;font-weight:600}.def-reading{color:var(--accent);font-size:14px}.def-senses{margin:0;padding-left:20px;display:flex;flex-direction:column;gap:6px;font-size:15px;line-height:1.5}.def-pos{display:inline-block;color:var(--muted);font-size:11px;border:1px solid var(--border);border-radius:6px;padding:0 5px;margin-right:6px}.line{display:flex;align-items:flex-start;gap:10px;width:100%;text-align:left;padding:12px;border-radius:12px;border:1px solid transparent;min-height:48px}.line.active{background:var(--surface-2);border-color:var(--accent)}.line.flagged{border-color:var(--flag)}.line:active{background:var(--surface)}.line-time{color:var(--muted);font-size:11px;font-variant-numeric:tabular-nums;margin-top:4px;flex-shrink:0;min-width:34px}.line-text{font-size:16px;line-height:1.6;overflow-wrap:anywhere}.line-flag{margin-left:auto;color:var(--flag);flex-shrink:0}.controls{flex-shrink:0;border-top:1px solid var(--border);background:var(--surface);padding:10px 16px calc(env(safe-area-inset-bottom) + 10px);display:flex;flex-direction:column;gap:6px}.seek-row{display:flex;align-items:center;gap:10px;font-size:11px;color:var(--muted);font-variant-numeric:tabular-nums}.seek-row input[type=range]{flex:1;height:32px;accent-color:var(--accent);margin:0}.buttons-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.ctl-btn{min-width:56px;min-height:56px;border-radius:50%;display:grid;place-items:center;font-size:22px;background:var(--surface-2)}.ctl-btn:active{background:var(--border)}.play-btn{width:68px;height:68px;font-size:24px;background:var(--accent);color:var(--accent-ink)}.play-btn:active{filter:brightness(1.15)}.speed-btn{min-width:58px;min-height:44px;border-radius:12px;font-size:14px;font-weight:650;color:var(--accent);background:var(--surface-2)}.speed-btn.spacer{visibility:hidden}.overlay{position:fixed;inset:0;z-index:20;background:var(--bg);display:flex;flex-direction:column;max-width:640px;margin:0 auto}.overlay-body{flex:1;overflow-y:auto;min-height:0;padding:0 12px calc(env(safe-area-inset-bottom) + 24px);display:flex;flex-direction:column}.coverage{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;color:var(--muted);line-height:1.5;margin:4px 0 8px}.coverage strong{color:var(--accent);font-size:18px}.syn-h{margin:18px 4px 10px;font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text)}.syn-hint{color:var(--muted);font-weight:500;text-transform:none;letter-spacing:normal}.syn-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.syn-row{display:flex;align-items:center;gap:12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:10px 12px;min-height:64px}.syn-word{display:flex;flex-direction:column;gap:2px;min-width:0}.syn-lemma{font-size:19px;font-weight:650;overflow-wrap:anywhere}.syn-reading{color:var(--muted);font-size:12px}.syn-meta{margin-left:auto;display:flex;align-items:center;gap:8px;color:var(--muted);font-size:12px;flex-shrink:0}.syn-pos{border:1px solid var(--border);border-radius:6px;padding:1px 6px}.know-btn{min-height:48px;padding:0 14px;border-radius:12px;background:var(--accent-dim);color:var(--accent);font-weight:650;flex-shrink:0}.know-btn:active{background:var(--accent);color:var(--accent-ink)}.words-btn{color:var(--accent);font-size:18px;border:1px solid var(--border)}.words-toolbar{display:flex;align-items:center;gap:10px;padding:0 12px 8px;flex-shrink:0;color:var(--muted);font-size:13px}.lang-select{min-height:44px;min-width:88px;background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:12px;padding:0 10px;font:inherit;font-size:15px;text-transform:uppercase}.lang-select:focus{outline:none;border-color:var(--accent)}.words-body{flex:1;overflow-y:auto;min-height:0;padding:0 12px calc(env(safe-area-inset-bottom) + 24px);display:flex;flex-direction:column}.syn-row.grad{border-color:var(--flag)}.grad-badge{align-self:flex-start;color:var(--flag);border:1px solid var(--flag);border-radius:6px;padding:1px 6px;font-size:11px;font-weight:700;white-space:nowrap}.grad-btn{min-height:48px;padding:0 14px;border-radius:12px;background:var(--flag);color:var(--flag-ink);font-weight:650;flex-shrink:0}.grad-btn:active{filter:brightness(1.15)}.recap-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;display:flex;flex-direction:column;gap:10px}.recap-audio{width:100%;min-height:44px}.recap-words{margin:0;color:var(--muted);font-size:13px;line-height:1.5;overflow-wrap:anywhere}.recap-notice{margin:0;color:var(--muted);font-size:13px;line-height:1.5}.recap-build{margin-top:0}.recap-build:disabled,.recap-rebuild:disabled{opacity:.55}.recap-rebuild{align-self:flex-start;padding:0}.takes-btn{align-self:center;min-height:44px;margin-right:8px;padding:0 10px;display:flex;align-items:center;gap:4px;border-radius:12px;border:1px solid var(--accent-dim);background:var(--accent-dim);color:var(--accent);font-size:13px;font-weight:650;flex-shrink:0}.takes-btn:active{filter:brightness(1.2)}.takes-ico{font-size:16px}.takes-hdr{color:var(--accent);font-size:18px;border:1px solid var(--border)}.takes-body{flex:1;overflow-y:auto;min-height:0;padding:0 12px calc(env(safe-area-inset-bottom) + 16px);display:flex;flex-direction:column}.takes-hint{color:var(--muted);font-size:13px;line-height:1.5;margin:4px 4px 10px}.takes-hint strong{color:var(--text)}.takes-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}.take-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:12px 14px;display:flex;flex-direction:column;gap:10px}.take-card.off{opacity:.6}.take-head{display:flex;align-items:center;gap:10px}.take-rank{flex-shrink:0;min-width:26px;height:26px;display:grid;place-items:center;border-radius:8px;background:var(--surface-2);color:var(--muted);font-size:13px;font-weight:700;font-variant-numeric:tabular-nums}.take-id{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}.take-name{font-size:15px;font-weight:650;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.take-win{color:var(--accent);background:var(--accent-dim);border-radius:6px;padding:1px 6px;font-size:11px;font-weight:700}.take-sub{color:var(--muted);font-size:12px;overflow-wrap:anywhere}.take-toggle{display:flex;align-items:center;gap:6px;flex-shrink:0;color:var(--muted);font-size:12px;font-weight:650}.take-toggle input{width:20px;height:20px;accent-color:var(--accent)}.cov-bar{position:relative;height:10px;border-radius:5px;background:var(--surface-2);overflow:hidden}.cov-seg{position:absolute;top:0;bottom:0;background:var(--accent);border-radius:5px;min-width:2px}.cov-seg.off{background:var(--muted)}.take-actions{display:flex;align-items:center;gap:8px}.take-reorder{display:flex;gap:4px;flex-shrink:0}.mini-btn{min-width:40px;min-height:40px;display:grid;place-items:center;border-radius:10px;border:1px solid var(--border);background:var(--surface-2);color:var(--text);font-size:16px;flex-shrink:0}.mini-btn:active{background:var(--border)}.mini-btn:disabled{opacity:.4}.mini-btn.danger{color:var(--flag)}.take-audio{flex:1;min-width:0;height:40px}.takes-foot{flex-shrink:0;border-top:1px solid var(--border);background:var(--surface);padding:10px 16px calc(env(safe-area-inset-bottom) + 12px);display:flex;flex-direction:column;align-items:stretch;gap:6px}.takes-foot .primary-btn{margin-top:0}.takes-foot .primary-btn:disabled{opacity:.5}.takes-status{margin:0;color:var(--accent);font-size:13px;text-align:center}.takes-warn{margin:0;color:var(--flag);font-size:13px;text-align:center}.drawer-backdrop{position:fixed;inset:0;z-index:30;background:#0000008c}.drawer{position:fixed;left:0;right:0;bottom:0;z-index:31;max-width:640px;margin:0 auto;background:var(--surface);border-radius:18px 18px 0 0;border:1px solid var(--border);border-bottom:none;padding:18px 16px calc(env(safe-area-inset-bottom) + 14px);display:flex;flex-direction:column;gap:14px}.drawer-title{margin:0;font-size:17px}.field label{display:block;font-size:12px;color:var(--muted);margin-bottom:6px}.field input{width:100%;min-height:48px;background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:12px;padding:0 12px;font-size:15px}.field input:focus{outline:none;border-color:var(--accent)}.row-between{display:flex;align-items:center;justify-content:space-between;color:var(--muted);font-size:13px}.linklike{color:var(--accent);min-height:44px;padding:0 10px;font-weight:600}.drawer-status{margin:0;color:var(--muted);font-size:13px;text-align:center}.drawer-close{align-self:center}
