:root{--bg:#0f172a;--surface:#1e293b;--border:#334155;--hover:#2d3a4f;--text:#cbd5e1;--text-h:#f1f5f9;--muted:#64748b;--red:#dc2626;--red-bg:#dc26261a;--green:#22c55e;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}@media (prefers-color-scheme:light){:root{--bg:#f8fafc;--surface:#fff;--border:#e2e8f0;--hover:#f1f5f9;--text:#475569;--text-h:#0f172a;--muted:#94a3b8;--red-bg:#dc26260f}}*{box-sizing:border-box}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;padding:0}#root{text-align:left;border:none;width:100%;max-width:100%;min-height:100dvh;margin:0}h1,h2,h3{color:var(--text-h);margin:0}button{font-family:inherit}.app{background:var(--bg);flex-direction:column;max-width:480px;height:100dvh;margin:0 auto;display:flex}.app-header{background:var(--red);color:#fff;text-align:center;flex-shrink:0;padding:12px 20px}.app-header h1{color:#fff;letter-spacing:1px;margin:0;font-size:20px;font-weight:700}.app-main{-webkit-overflow-scrolling:touch;flex:1;padding:16px;overflow-y:auto}.tab-bar{border-top:1px solid var(--border);background:var(--surface);padding-bottom:env(safe-area-inset-bottom);flex-shrink:0;display:flex}.tab-bar button{color:var(--muted);cursor:pointer;background:0 0;border:none;flex-direction:column;flex:1;align-items:center;gap:2px;padding:8px 0;font-size:11px;transition:color .2s;display:flex}.tab-bar button.active{color:var(--red)}.tab-icon{font-size:20px}.review-launch{border:2px solid var(--red);background:var(--red-bg);width:100%;color:var(--text);cursor:pointer;border-radius:16px;align-items:center;gap:12px;margin-bottom:20px;padding:16px;transition:transform .1s;display:flex}.review-launch:active{transform:scale(.98)}.review-icon{font-size:32px}.review-info{text-align:left;flex-direction:column;flex:1;gap:2px;display:flex}.review-info strong{color:var(--text-h);font-size:16px}.review-info span{color:var(--muted);font-size:13px}.review-arrow{color:var(--red);font-size:24px}.category-list{flex-direction:column;gap:10px;display:flex}.category-card{border:1px solid var(--border);background:var(--surface);cursor:pointer;text-align:left;border-radius:14px;align-items:center;gap:14px;width:100%;padding:14px 16px;transition:background .2s;display:flex}.category-card:active{background:var(--hover)}.cat-emoji{flex-shrink:0;font-size:28px}.cat-info{flex:1;min-width:0}.cat-name{color:var(--text-h);font-size:15px;font-weight:600}.cat-desc{color:var(--muted);margin-top:2px;font-size:12px}.cat-progress{align-items:center;gap:8px;margin-top:6px;display:flex}.cat-bar{background:var(--border);border-radius:2px;flex:1;height:4px;overflow:hidden}.cat-bar-fill{background:var(--green);border-radius:2px;height:100%;transition:width .3s}.cat-count{color:var(--muted);flex-shrink:0;font-size:11px}.phrase-list-header{align-items:center;gap:12px;margin-bottom:16px;display:flex}.phrase-list-header h2{margin:0;font-size:18px}.back-btn{background:var(--surface);border:1px solid var(--border);cursor:pointer;color:var(--text);border-radius:10px;padding:6px 12px;font-size:18px}.phrase-items{flex-direction:column;gap:8px;display:flex}.phrase-card{border:1px solid var(--border);background:var(--surface);cursor:pointer;border-radius:14px;align-items:center;gap:12px;padding:14px 16px;transition:background .2s;display:flex}.phrase-card:active{background:var(--hover)}.phrase-main{flex:1;min-width:0}.phrase-chinese{color:var(--text-h);margin-bottom:2px;font-size:22px;font-weight:600}.phrase-pinyin{color:var(--red);margin-bottom:2px;font-size:14px}.phrase-french{color:var(--text);font-size:14px}.phrase-literal{color:var(--muted);font-size:12px;font-style:italic}.phrase-actions{flex-direction:column;align-items:center;gap:4px;display:flex}.fav-btn{color:var(--muted);cursor:pointer;background:0 0;border:none;padding:4px;font-size:22px}.fav-btn.active{color:#f59e0b}.diff{letter-spacing:2px;font-size:8px}.diff-1{color:var(--green)}.diff-2{color:#eab308}.diff-3{color:var(--red)}.review-session{flex-direction:column;height:100%;display:flex}.review-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.review-progress{color:var(--muted);font-size:14px}.review-score{color:var(--green);font-size:14px;font-weight:600}.review-card{border:2px solid var(--border);background:var(--surface);cursor:pointer;border-radius:20px;flex-direction:column;flex:1;justify-content:center;align-items:center;min-height:250px;padding:32px 20px;transition:border-color .2s;display:flex}.review-card:active{border-color:var(--red)}.review-chinese{color:var(--text-h);margin-bottom:8px;font-size:42px;font-weight:700}.review-pinyin{color:var(--red);margin-bottom:20px;font-size:18px}.review-answer{text-align:center}.review-french{color:var(--text-h);font-size:20px;font-weight:500}.review-literal{color:var(--muted);margin-top:4px;font-size:14px;font-style:italic}.review-tap{color:var(--muted);border:1px dashed var(--border);border-radius:8px;padding:12px 24px;font-size:14px}.review-ratings{flex-wrap:wrap;justify-content:center;gap:6px;margin-top:16px;display:flex}.rating-btn{background:var(--surface);cursor:pointer;border:2px solid;border-radius:10px;flex:1;min-width:60px;padding:10px 12px;font-size:13px;font-weight:600;transition:transform .1s,background .2s}.rating-btn:active{transform:scale(.95)}.review-done{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:12px;height:100%;display:flex}.review-done-icon{font-size:64px}.review-done h2{margin:0}.primary-btn{background:var(--red);color:#fff;cursor:pointer;border:none;border-radius:12px;margin-top:8px;padding:12px 32px;font-size:16px;font-weight:600}.search-input{border:1px solid var(--border);background:var(--surface);width:100%;color:var(--text-h);box-sizing:border-box;border-radius:14px;outline:none;margin-bottom:16px;padding:14px 16px;font-size:16px}.search-input:focus{border-color:var(--red)}.no-results{text-align:center;color:var(--muted);padding:32px}.stats-view h2{margin:0 0 16px;font-size:20px}.stats-grid{grid-template-columns:1fr 1fr;gap:10px;margin-bottom:20px;display:grid}.stat-box{border:1px solid var(--border);background:var(--surface);text-align:center;border-radius:14px;padding:16px}.stat-number{color:var(--text-h);font-size:28px;font-weight:700}.stat-number.accent{color:var(--red)}.stat-label{color:var(--muted);margin-top:2px;font-size:12px}.progress-section{margin-bottom:24px}.progress-label{color:var(--text);justify-content:space-between;margin-bottom:8px;font-size:13px;display:flex}.progress-bar{background:var(--border);border-radius:5px;height:10px;display:flex;overflow:hidden}.progress-fill.mastered{background:var(--green)}.progress-fill.learned{background:#eab308}.progress-legend{color:var(--muted);gap:16px;margin-top:8px;font-size:12px;display:flex}.dot{border-radius:50%;width:8px;height:8px;margin-right:4px;display:inline-block}.dot.mastered{background:var(--green)}.dot.learned{background:#eab308}.dot.new{background:var(--border)}.chart-section h3{color:var(--text);margin:0 0 12px;font-size:14px}.mini-chart{align-items:flex-end;gap:6px;height:80px;display:flex}.chart-bar-wrap{flex-direction:column;flex:1;justify-content:flex-end;align-items:center;height:100%;display:flex}.chart-bar{background:var(--red);border-radius:4px 4px 0 0;width:100%;min-height:4px;transition:height .3s}.chart-label{color:var(--muted);margin-top:4px;font-size:10px}.favorites-view h2{margin:0 0 16px;font-size:20px}.empty-state{height:60%;color:var(--muted);text-align:center;flex-direction:column;justify-content:center;align-items:center;display:flex}.empty-icon{margin-bottom:12px;font-size:48px}
