:root{--bg: oklch(98.4% .004 250);--surface: oklch(100% 0 0);--surface-2: oklch(96.6% .005 250);--fg: oklch(18% .018 250);--fg-2: oklch(30% .018 250);--muted: oklch(50% .014 250);--meta: oklch(62% .012 250);--border: oklch(91% .006 250);--border-strong: oklch(82% .008 250);--accent: oklch(34% .06 245);--accent-2: oklch(28% .06 245);--accent-soft: oklch(95% .014 245);--hi: oklch(72% .14 65);--hi-soft: oklch(95% .045 75);--success: oklch(55% .14 145);--success-soft: oklch(95% .04 145);--warn: oklch(65% .14 55);--warn-soft: oklch(95% .04 55);--danger: oklch(55% .16 25);--danger-soft: oklch(95% .04 25);--shadow-md: 0 14px 40px -18px rgba(20,24,40,.18);--radius: 10px;--radius-lg: 16px;--gutter: 16px;--font-display: "Iowan Old Style", Charter, Georgia, "Noto Serif TC", serif;--font-body: -apple-system, BlinkMacSystemFont, "SF Pro Text", "PingFang TC", "Noto Sans TC", system-ui, sans-serif;--font-mono: ui-monospace, "JetBrains Mono", "IBM Plex Mono", Menlo, monospace}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%}body{background:var(--bg);color:var(--fg);font-family:var(--font-body);font-size:15px;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:inherit;text-decoration:none}button,input,select{font:inherit;border:none;background:none}button{cursor:pointer}input,select{outline:none}ul,ol{list-style:none}img{max-width:100%;display:block}.topnav{position:sticky;top:0;z-index:100;height:48px;display:flex;align-items:center;gap:12px;padding:0 var(--gutter);background:color-mix(in oklch,var(--bg) 80%,transparent);backdrop-filter:blur(16px) saturate(1.4);-webkit-backdrop-filter:blur(16px) saturate(1.4);border-bottom:1px solid var(--border)}.topnav-brand{font-family:var(--font-display);font-size:17px;font-weight:500;letter-spacing:-.02em;color:var(--fg)}.menu-btn{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;color:var(--fg-2);transition:background .15s}.menu-btn:hover{background:var(--surface-2)}.topnav-links{display:none;align-items:center;gap:4px;margin-left:auto}.topnav-link{padding:6px 14px;border-radius:8px;font-size:13px;color:var(--muted);transition:background .15s,color .15s}.topnav-link:hover{background:var(--surface-2);color:var(--fg-2)}.topnav-link.active{background:var(--accent-soft);color:var(--accent)}.topnav-streak{display:flex;align-items:center;gap:5px;font-family:var(--font-mono);font-size:11px;font-variant-numeric:tabular-nums;color:var(--accent);background:var(--accent-soft);padding:3px 9px;border-radius:99px;flex-shrink:0}.topnav-streak svg{width:12px;height:12px;color:var(--hi)}.drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#0000004d;opacity:0;pointer-events:none;transition:opacity .25s}.drawer-overlay.open{opacity:1;pointer-events:auto}.drawer{position:fixed;top:0;left:0;bottom:0;z-index:201;width:280px;background:var(--surface);border-right:1px solid var(--border);transform:translate(-100%);transition:transform .25s ease;display:flex;flex-direction:column}.drawer.open{transform:translate(0)}.drawer-head{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}.drawer-brand{font-family:var(--font-display);font-size:20px;font-weight:600;color:var(--fg)}.drawer-close{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:8px;color:var(--muted);transition:background .15s,color .15s}.drawer-close:hover{background:var(--surface-2);color:var(--fg-2)}.drawer-nav{display:flex;flex-direction:column;padding:12px;gap:2px}.drawer-link{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:10px;font-size:15px;font-weight:500;color:var(--fg-2);transition:background .15s,color .15s}.drawer-link svg{width:20px;height:20px;flex-shrink:0}.drawer-link:hover{background:var(--surface-2)}.drawer-link.active{background:var(--accent-soft);color:var(--accent)}.drawer-link.active svg{stroke:var(--accent)}.mini-player{position:fixed;bottom:0;left:0;right:0;z-index:90;background:color-mix(in oklch,var(--surface) 96%,transparent);backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px);border-top:1px solid var(--border);padding-bottom:env(safe-area-inset-bottom,0px)}.mp-progress{display:block;position:relative;width:100%;height:2px;padding:0;background:var(--surface-2);text-align:left;cursor:pointer}.mp-progress-fill,.mp-progress .fill{position:absolute;inset:0 auto 0 0;height:100%;background:var(--accent);border-radius:0 99px 99px 0;transition:width .1s linear}.mp-main{display:flex;align-items:center;gap:10px;max-width:640px;margin-inline:auto;padding:7px 14px}.mp-info{display:flex;flex:1;min-width:0;flex-direction:column;align-items:flex-start;text-align:left;cursor:pointer}.mp-title{max-width:100%;color:var(--fg);font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mp-sub{max-width:100%;margin-top:1px;color:var(--meta);font-family:var(--font-mono);font-size:10px;letter-spacing:.02em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mp-transport{display:flex;align-items:center;gap:2px;flex-shrink:0}.mp-tb{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;color:var(--fg-2);-webkit-tap-highlight-color:transparent;transition:background .15s,color .15s,opacity .15s}.mp-tb:focus:not(:focus-visible){outline:none}.mp-tb:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.mp-tb:hover:not(:disabled){background:var(--surface-2);color:var(--fg)}.mp-tb:disabled{cursor:default;opacity:.35}.mp-tb svg{width:14px;height:14px;display:block}.mp-tb.mp-play,.mp-tb.play{width:40px;height:40px;margin:0 2px;border-radius:50%;background:var(--accent);color:#fff}.mp-tb.mp-play:hover,.mp-tb.play:hover{background:var(--accent-2)}.mp-tb.mp-play svg,.mp-tb.play svg{width:16px;height:16px}.mp-controls{display:flex;align-items:center;gap:6px;max-width:640px;margin-inline:auto;padding:0 14px 8px;overflow-x:auto}.mp-chip,.mp-select-wrap{display:inline-flex;align-items:center;gap:4px;flex-shrink:0;padding:4px 10px;border:1px solid var(--border);border-radius:6px;background:transparent;color:var(--fg-2);font-family:var(--font-mono);font-size:11px;letter-spacing:.02em;transition:border-color .15s,background .15s,color .15s,box-shadow .15s}.mp-chip:hover,.mp-select-wrap:hover{border-color:var(--border-strong)}.mp-chip.on,.mp-chip.active{border-color:transparent;background:var(--accent-soft);color:var(--accent)}.mp-chip .cl,.mp-select-wrap .cl{margin-right:2px;color:var(--meta);font-size:9px;letter-spacing:.08em;text-transform:uppercase}.mp-chip.on .cl,.mp-chip.active .cl{color:color-mix(in oklch,var(--accent) 60%,transparent)}.mp-select-wrap{position:relative;padding-right:8px;cursor:pointer}.mp-select-wrap:focus-within{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-soft)}.mp-select{min-width:0;padding:0 14px 0 0;-moz-appearance:none;appearance:none;-webkit-appearance:none;border:0;background:none;color:inherit;font:inherit;font-family:var(--font-mono);font-size:11px;outline:none;cursor:pointer}.mp-select option{background:var(--surface);color:var(--fg)}.mp-select-wrap:after{content:"";width:0;height:0;border-left:3.5px solid transparent;border-right:3.5px solid transparent;border-top:4px solid var(--meta);pointer-events:none;flex-shrink:0}@media (max-width: 767px){.mp-main{gap:8px;padding:6px 12px}.mp-tb{width:40px;height:40px}.mp-tb.mp-play,.mp-tb.play{width:44px;height:44px}.mp-controls{gap:5px;padding:0 12px 6px}.mp-chip,.mp-select-wrap{padding:5px 10px}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;min-height:40px;padding:8px 18px;border-radius:var(--radius);font-size:14px;font-weight:500;color:var(--fg-2);background:var(--surface);border:1px solid var(--border);transition:border-color .15s,background .15s,color .15s}.btn:hover{border-color:var(--border-strong);background:var(--surface-2)}.btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn.primary:hover{background:var(--accent-2);border-color:var(--accent-2)}.section-label{margin:0 0 12px;color:var(--meta);font-family:var(--font-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase}.home{max-width:480px;margin:0 auto;padding:12px var(--gutter) 24px}.continue{display:flex;flex-direction:column;gap:12px;margin-bottom:20px;padding:16px;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);box-shadow:var(--shadow-md)}.continue-head{display:flex;align-items:center;justify-content:space-between;color:var(--meta);font-family:var(--font-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase}.continue-head .dot{width:6px;height:6px;border-radius:50%;background:var(--hi);box-shadow:0 0 0 3px var(--hi-soft)}.continue-title{margin:0;color:var(--fg);font-family:var(--font-display);font-size:17px;font-weight:500;line-height:1.3;letter-spacing:-.01em}.continue-source{margin:0;color:var(--meta);font-family:var(--font-mono);font-size:12px;letter-spacing:.02em}.progress-track{position:relative;height:3px;border-radius:99px;background:var(--surface-2);overflow:hidden}.progress-fill{position:absolute;inset:0 auto 0 0;border-radius:99px;background:var(--accent);transition:width .3s}.progress-row{display:flex;justify-content:space-between;margin-top:6px;color:var(--meta);font-family:var(--font-mono);font-size:11px;font-variant-numeric:tabular-nums}.continue-actions{display:flex;gap:8px;margin-top:2px}.btn .icon{display:inline-flex;width:14px;height:14px}.btn .icon svg{width:100%;height:100%}.recent-courses{display:flex;flex-direction:column;gap:0;margin-bottom:16px;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);overflow:hidden}.course-row{display:flex;align-items:center;gap:12px;padding:12px 14px;border-bottom:1px solid var(--border);transition:background .15s;cursor:pointer}.course-row:last-child{border-bottom:none}.course-row:hover{background:var(--surface-2)}.course-cover{display:grid;place-items:center;flex-shrink:0;width:40px;height:40px;border-radius:8px;background:var(--accent-soft);color:var(--accent)}.course-cover svg{width:18px;height:18px}.review-cover{background:var(--hi-soft);color:var(--hi)}.course-info{display:flex;flex:1;min-width:0;flex-direction:column;gap:2px}.course-name{color:var(--fg);font-size:14px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.course-meta{color:var(--meta);font-family:var(--font-mono);font-size:11px;letter-spacing:.02em}.course-progress{width:48px;flex-shrink:0;text-align:right}.course-pct{color:var(--accent);font-family:var(--font-mono);font-size:12px;font-variant-numeric:tabular-nums}.review-cta{color:var(--hi)}.view-all{display:block;margin-top:12px;padding:8px;border-radius:8px;color:var(--fg-2);font-size:13px;text-align:center;transition:background .15s,color .15s}.view-all:hover{background:var(--surface-2);color:var(--fg)}.player-page{max-width:1180px;margin:0 auto;padding:clamp(24px,4vw,48px) var(--gutter) 120px}.player-shell{display:flex;flex-direction:column;min-height:calc(100vh - 200px);overflow:hidden;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.player-main{flex:1;min-width:0;padding:0 clamp(28px,3.4vw,40px) clamp(28px,3.4vw,40px)}.player-head{padding:clamp(28px,3.4vw,40px) clamp(28px,3.4vw,40px) 16px;margin-bottom:0}.player-title{font-family:var(--font-display);font-size:22px;font-weight:500;color:var(--fg);line-height:1.3}.player-sub{font-size:13px;color:var(--meta);margin-top:4px}.breadcrumb{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--meta);margin-bottom:12px}.breadcrumb a{color:var(--accent)}.breadcrumb a:hover{text-decoration:underline}.breadcrumb .sep{color:var(--border-strong)}.breadcrumb .current{color:var(--fg-2)}.sentence-list{display:flex;flex-direction:column;gap:2px}.sentence{display:grid;position:relative;grid-template-columns:1fr 32px;gap:12px;align-items:start;padding:14px 0;border-top:1px solid var(--border);transition:background .15s,opacity .15s;cursor:pointer}.sentence:first-child{border-top:none}.sentence:hover{background:var(--surface-2)}.sentence .body{min-width:0}.sentence .en{font-size:15px;line-height:1.5;color:var(--fg)}.sentence .zh{font-size:13px;color:var(--meta);margin-top:2px}.sentence .phrases{display:inline-flex;flex-wrap:wrap;gap:4px;margin-top:6px}.phrase{padding:2px 8px;border-radius:6px;font-size:13px;background:var(--surface-2);color:var(--fg-2);transition:background .15s,color .15s}.phrase.active{background:var(--accent);color:#fff}.sentence mark{background:none;text-decoration:underline;text-decoration-color:var(--hi);text-decoration-thickness:2px;text-underline-offset:3px}.sentence.active{background:linear-gradient(to right,var(--accent-soft),transparent 80%);padding-left:12px}.sentence.active:before{content:"";position:absolute;left:0;top:8px;bottom:8px;width:3px;border-radius:99px;background:var(--accent)}.sentence.active .en{color:var(--fg);font-weight:500}.sentence.upcoming{opacity:.55}.fav button{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:8px;color:var(--meta);transition:color .15s,background .15s}.fav button:hover{background:var(--surface-2);color:var(--danger)}.fav button.active{color:var(--danger)}.lib-page{max-width:640px;margin:0 auto;padding:16px var(--gutter) 32px}.lang-filter{display:flex;gap:6px;margin-bottom:16px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:2px}.lang-filter::-webkit-scrollbar{display:none}.lang-chip{display:inline-flex;align-items:center;flex-shrink:0;height:32px;padding:0 14px;border:1px solid var(--border);border-radius:99px;background:var(--surface);color:var(--muted);font-size:13px;white-space:nowrap;cursor:pointer;transition:background .15s,color .15s,border-color .15s}.lang-chip:hover{color:var(--fg);border-color:var(--border-strong)}.lang-chip.active{background:var(--accent);border-color:var(--accent);color:#fff}.chip-count{margin-left:5px;font-family:var(--font-mono);font-size:10px;opacity:.65;font-variant-numeric:tabular-nums}.sort-bar{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.result-count{color:var(--muted);font-size:13px}.result-count strong{color:var(--fg);font-weight:500}.sort-select{height:32px;padding:0 28px 0 10px;-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--fg-2);font-size:12px;cursor:pointer}.collection{overflow:hidden;margin-bottom:10px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);transition:border-color .15s}.collection:hover{border-color:var(--border-strong)}.coll-head{display:flex;align-items:center;gap:12px;width:100%;padding:14px;text-align:left;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .15s}.coll-head:hover{background:var(--surface-2)}.coll-icon{display:grid;place-items:center;flex-shrink:0;width:36px;height:36px;border-radius:8px;background:var(--accent-soft);color:var(--accent)}.coll-icon svg{width:16px;height:16px}.coll-info{flex:1;min-width:0}.coll-name{color:var(--fg);font-size:14px;font-weight:500;line-height:1.3}.coll-meta{display:flex;align-items:center;gap:6px;margin-top:2px;color:var(--meta);font-family:var(--font-mono);font-size:11px;font-variant-numeric:tabular-nums}.lang-dot{width:5px;height:5px;border-radius:50%;background:var(--accent);flex-shrink:0}.lang-dot.en{background:#4a7ccc}.lang-dot.ja{background:#cc4a5e}.lang-dot.ko{background:#5eaa4a}.coll-badge{flex-shrink:0;padding:2px 7px;border-radius:5px;background:var(--surface-2);color:var(--meta);font-family:var(--font-mono);font-size:10px;font-variant-numeric:tabular-nums}.coll-chevron{width:20px;height:20px;color:var(--meta);flex-shrink:0;transition:transform .2s}.collection.open .coll-chevron{transform:rotate(180deg)}.coll-body{max-height:0;overflow:hidden;transition:max-height .3s ease-out}.collection.open .coll-body{max-height:2000px;transition:max-height .5s ease-in}.ep-list{border-top:1px solid var(--border)}.ep-row{display:flex;align-items:center;gap:10px;padding:10px 14px 10px 24px;border-bottom:1px solid color-mix(in oklch,var(--border) 50%,transparent);cursor:pointer;transition:background .15s}.ep-row:last-child{border-bottom:none}.ep-row:hover{background:var(--surface-2)}.ep-play{display:grid;place-items:center;flex-shrink:0;width:28px;height:28px;border:1px solid var(--border);border-radius:50%;color:var(--muted);transition:border-color .15s,color .15s}.ep-play:hover{border-color:var(--accent);color:var(--accent)}.ep-play svg{width:10px;height:10px}.ep-info{flex:1;min-width:0}.ep-title{color:var(--fg);font-size:13px;line-height:1.35;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ep-details{display:flex;align-items:center;gap:6px;margin-top:3px;color:var(--meta);font-family:var(--font-mono);font-size:10px;font-variant-numeric:tabular-nums}.ep-details .sep{color:var(--border-strong)}.ep-progress{flex-shrink:0;width:36px;color:var(--fg-2);font-family:var(--font-mono);font-size:11px;text-align:right;font-variant-numeric:tabular-nums}.ep-progress.done{color:var(--accent)}.ep-progress.active{color:var(--hi)}.empty-state{display:none;text-align:center;padding:48px 24px;color:var(--muted);font-size:14px}.empty-state.visible{display:block}.review-page{max-width:480px;margin:0 auto;padding:16px var(--gutter) 32px}.review-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:16px}.rs-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:12px 10px;text-align:center}.rs-num{font-family:var(--font-mono);font-size:22px;font-weight:500;font-variant-numeric:tabular-nums;line-height:1.2}.rs-num.due{color:var(--hi)}.rs-num.learned{color:var(--success)}.rs-num.total{color:var(--accent)}.rs-label{margin-top:4px;color:var(--meta);font-family:var(--font-mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase}.review-progress{margin-bottom:20px}.rp-track{height:4px;border-radius:99px;background:var(--surface-2);overflow:hidden}.rp-fill{height:100%;border-radius:99px;background:var(--success);transition:width .4s ease}.rp-label{display:flex;justify-content:space-between;margin-top:6px;color:var(--meta);font-family:var(--font-mono);font-size:11px;font-variant-numeric:tabular-nums}.queue-info{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;color:var(--meta);font-family:var(--font-mono);font-size:11px}.queue-info .qi-num{color:var(--fg);font-weight:500}.card-scene{perspective:800px;margin-bottom:16px}.review-card{position:relative;min-height:200px;cursor:pointer;transition:transform .4s ease;transform-style:preserve-3d}.review-card.flipped{transform:rotateX(8deg) scale(.98)}.card-face{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px 24px;box-shadow:var(--shadow-md);transition:opacity .25s,border-color .2s}.card-face:hover{border-color:var(--border-strong)}.card-source{display:flex;align-items:center;gap:8px;margin-bottom:12px;color:var(--meta);font-family:var(--font-mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase}.card-source .src-dot{width:5px;height:5px;border-radius:50%;background:var(--hi)}.card-time{margin-left:auto;color:var(--meta);font-family:var(--font-mono);font-size:10px;letter-spacing:.04em}.card-sentence{margin-bottom:8px;color:var(--fg);font-size:18px;line-height:1.65;letter-spacing:-.005em}.card-actions{display:flex;align-items:center;gap:8px;margin-bottom:4px}.card-audio,.card-context{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:8px;background:var(--surface-2);color:var(--fg-2);font-family:var(--font-mono);font-size:11px;cursor:pointer;transition:background .15s,color .15s}.card-context{gap:5px}.card-audio:hover,.card-context:hover{background:var(--accent-soft);color:var(--accent)}.card-audio.playing{background:var(--accent);color:#fff}.card-audio svg{width:14px;height:14px;flex-shrink:0}.card-context svg{width:13px;height:13px;flex-shrink:0}.card-answer{display:none;margin-top:16px;padding-top:16px;border-top:1px solid var(--border)}.review-card.flipped .card-answer{display:block}.card-answer-label{margin-bottom:8px;color:var(--meta);font-family:var(--font-mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase}.card-translation{color:var(--fg-2);font-size:15px;line-height:1.6}.card-phrase{display:inline-flex;align-items:center;margin-top:10px;padding:3px 10px;border:1px solid transparent;border-radius:6px;background:var(--hi-soft);color:#683c00;color:oklch(40% .12 65);font-size:13px}.card-hint{margin-top:10px;color:var(--meta);font-family:var(--font-mono);font-size:11px;letter-spacing:.04em;text-align:center}.rating-row{display:none;grid-template-columns:repeat(4,1fr);gap:6px;margin-top:12px}.rating-row.visible{display:grid}.rate-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px 6px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);transition:all .15s}.rate-btn:hover{border-color:var(--border-strong);background:var(--surface-2)}.rate-btn:active{transform:scale(.96)}.rate-btn .rate-label{color:var(--fg);font-size:13px;font-weight:500}.rate-btn .rate-interval{color:var(--meta);font-family:var(--font-mono);font-size:10px;font-variant-numeric:tabular-nums}.rate-btn.again .rate-label{color:var(--danger)}.rate-btn.hard .rate-label{color:var(--warn)}.rate-btn.good .rate-label{color:var(--success)}.rate-btn.easy .rate-label{color:var(--accent)}.review-done{display:none;text-align:center;padding:48px 24px}.review-done.visible{display:block}.done-icon{display:grid;place-items:center;width:64px;height:64px;margin:0 auto 20px;border-radius:50%;background:var(--success-soft);color:var(--success)}.done-icon svg{width:28px;height:28px}.done-title{margin:0 0 8px;font-family:var(--font-display);font-size:20px;font-weight:500}.done-sub{margin:0 0 24px;color:var(--muted);font-size:14px}.done-stats{display:flex;justify-content:center;gap:24px;color:var(--meta);font-family:var(--font-mono);font-size:12px}.done-stats strong{display:block;margin-bottom:2px;color:var(--fg);font-size:16px;font-weight:500}.my-page{max-width:480px;margin:0 auto;padding:24px var(--gutter) 100px}.profile{display:flex;align-items:center;gap:16px;margin-bottom:24px}.avatar{width:56px;height:56px;border-radius:50%;background:var(--accent-soft);display:grid;place-items:center;flex-shrink:0;font-size:22px;font-weight:600;color:var(--accent)}.profile-info{flex:1;min-width:0}.profile-name{font-size:18px;font-weight:600;color:var(--fg)}.profile-meta{font-size:13px;color:var(--meta);margin-top:2px}.stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:24px}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px;text-align:center}.stat-num{font-size:24px;font-weight:700;color:var(--fg);line-height:1;font-variant-numeric:tabular-nums}.stat-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--meta);margin-top:4px}.contrib-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px;overflow-x:auto}.contrib-months{display:flex;font-size:11px;color:var(--meta);margin-bottom:6px;padding-left:24px}.contrib-body{display:flex;gap:3px}.contrib-days{display:flex;flex-direction:column;gap:3px;font-size:10px;color:var(--meta);padding-right:4px;min-width:20px}.contrib-grid{display:flex;gap:3px;flex:1}.contrib-col{display:flex;flex-direction:column;gap:3px}.contrib-cell{width:10px;height:10px;border-radius:2px;background:var(--surface-2)}.contrib-cell[data-level="1"]{background:color-mix(in oklch,var(--accent) 25%,var(--surface-2))}.contrib-cell[data-level="2"]{background:color-mix(in oklch,var(--accent) 50%,var(--surface-2))}.contrib-cell[data-level="3"]{background:color-mix(in oklch,var(--accent) 75%,var(--surface-2))}.contrib-cell[data-level="4"]{background:var(--accent)}.contrib-legend{display:flex;align-items:center;justify-content:flex-end;gap:4px;margin-top:8px;font-size:11px;color:var(--meta)}.contrib-legend .contrib-cell{width:10px;height:10px}.login-page{display:flex;align-items:center;justify-content:center;min-height:calc(100vh - 48px);padding:var(--gutter)}.login-card{width:100%;max-width:380px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:32px;box-shadow:var(--shadow-md)}.login-card h1{font-family:var(--font-display);font-size:24px;font-weight:500;margin-bottom:6px}.login-card p{font-size:14px;color:var(--meta);margin-bottom:24px}.login-form{display:flex;flex-direction:column;gap:12px}.login-form label{font-size:13px;font-weight:600;color:var(--fg-2)}.login-form input{width:100%;min-height:44px;padding:10px 14px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--fg);font-size:15px;transition:border-color .15s}.login-form input:focus{border-color:var(--accent)}.login-error{font-size:13px;color:var(--danger);margin-top:4px}.import-page{max-width:560px;margin:0 auto;padding:24px var(--gutter) 100px}.import-page h1{font-family:var(--font-display);font-size:22px;font-weight:500;margin-bottom:20px}.import-form{display:flex;flex-direction:column;gap:16px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:13px;font-weight:600;color:var(--fg-2)}.form-group input,.form-group select{width:100%;min-height:44px;padding:10px 14px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--fg);font-size:15px;transition:border-color .15s}.form-group input:focus,.form-group select:focus{border-color:var(--accent)}.import-status{padding:16px;border-radius:var(--radius);background:var(--surface-2);font-size:14px;color:var(--fg-2)}.import-status.error{background:var(--danger-soft);color:var(--danger)}.import-status.success{background:var(--success-soft);color:var(--success)}main{min-height:calc(100vh - 48px)}.page-title{font-family:var(--font-display);font-size:28px;font-weight:600;line-height:1.2;letter-spacing:-.02em;margin-bottom:16px}.status{padding:24px var(--gutter);color:var(--meta);text-align:center}.status.error,.error{color:var(--danger)}.empty-state .btn{margin-top:18px}.section-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}.section-head.compact{margin-bottom:14px}.view-inline{color:var(--accent);font-size:13px;font-weight:600}.view-inline:hover{text-decoration:underline}.home-summary{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:28px}.summary-card{display:flex;flex-direction:column;gap:4px;padding:16px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface)}.summary-value{font-size:26px;font-weight:700;line-height:1;color:var(--accent);font-variant-numeric:tabular-nums}.summary-label{font-size:12px;color:var(--meta)}.sentence-time-inline{margin-top:6px;font-family:var(--font-mono);font-size:11px;color:var(--meta)}.mp-chip.active{border-color:transparent;background:var(--accent-soft);color:var(--accent)}.reveal-btn{width:100%;margin-bottom:12px}.coll-head{width:100%;text-align:left}.mini-info,.mp-info{display:flex;flex:1;min-width:0;flex-direction:column;align-items:flex-start;text-align:left;cursor:pointer}.control-btn svg,.mp-tb svg,.ep-play svg{display:block}.fav-btn{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:8px;color:var(--meta);transition:color .15s,background .15s}.fav-btn:hover{background:var(--surface-2);color:var(--danger)}.fav-btn.active{color:var(--danger)}.action-link{display:inline-flex;align-items:center;justify-content:center;min-height:40px;padding:8px 18px;border-radius:var(--radius);font-size:14px;font-weight:500;color:var(--fg-2);background:var(--surface);border:1px solid var(--border)}.action-link.primary{background:var(--accent);border-color:var(--accent);color:#fff}.panel{max-width:560px;margin:0 auto;padding:24px var(--gutter) 100px}.title{font-family:var(--font-display);font-size:24px;font-weight:600;line-height:1.2;margin-bottom:8px}.subtitle{color:var(--meta);margin-bottom:18px}.field-label{display:block;margin-bottom:6px;font-size:13px;font-weight:600;color:var(--fg-2)}.text-field{width:100%;min-height:44px;padding:10px 14px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--fg)}.text-field:focus{border-color:var(--accent)}.login-btn{width:100%}@media (min-width: 768px){.menu-btn{display:none}.topnav-links{display:flex}.topnav-streak{margin-left:0}.drawer-overlay,.drawer{display:none}.home{max-width:640px}.lib-page{max-width:720px}.review-page{max-width:520px}.my-page{max-width:560px}.player-page{max-width:1180px}}@media (max-width: 767px){.topnav-links{display:none}.player-page{padding:12px 0 120px}.player-shell{border:none;border-radius:12px;box-shadow:none}.player-main{padding:0 16px 16px}.player-head{padding:16px 16px 12px}}
