:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}body{margin:0}#root{text-align:center;border-inline:1px solid var(--border);box-sizing:border-box;flex-direction:column;width:1126px;max-width:100%;min-height:100svh;margin:0 auto;display:flex}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--primary:#007aff;--primary-dark:#0056cc;--primary-glow:#007aff40;--primary-soft:#007aff1a;--accent:#667eff;--accent-dark:#4f97ff;--page-gutter:1rem;--bg:#f2f2f7;--bg-secondary:#e5e5ea;--surface:#fff;--surface-hover:#f5f5fa;--text:#000;--text-secondary:#3c3c43;--text-muted:#aeaeb2;--border:#e0e4f8;--border-light:#eceeff;--success:#34c759;--warning:#ff9500;--danger:#ef4444;--hot-bg:#fff7ed;--hot-border:#fed7aa;--fav-color:#f43f5e;--radius:20px;--radius-sm:16px;--radius-xs:12px;--shadow:0 1px 3px #0000000a, 0 1px 2px #0000000f;--shadow-md:0 4px 12px #00000014, 0 2px 4px #0000000a;--shadow-lg:0 10px 30px #0000001a, 0 4px 10px #0000000f;--hdr-h:64px}[data-theme=dark]{--bg:#0d0f23;--bg-secondary:#141632;--surface:#1a1e3a;--surface-hover:#202448;--text:#e8ecff;--text-secondary:#8890c0;--text-muted:#555a88;--border:#667eea2e;--border-light:#667eea1a;--primary:#0a84ff;--primary-dark:#409cff;--primary-glow:#818cf840;--primary-soft:#818cf81a;--accent:#8b95ff;--accent-dark:#6ab0ff;--hot-bg:#1c1208;--hot-border:#78350f;--shadow:0 4px 20px #0006;--shadow-md:0 8px 32px #00000080;--shadow-lg:0 16px 48px #0009}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{min-height:100vh;min-height:calc(var(--vh,1) * 100);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(#f2f2f7 0%,#e8e8ed 50%,#f2f2f7 100%);min-height:100dvh;font-family:Noto Sans Lao,Noto Sans,-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;transition:background-color .25s,color .25s,border-color .25s,box-shadow .25s}*,:before,:after{transition:background-color .25s,color .25s,border-color .25s}[data-theme=dark] body{background:linear-gradient(#0d0f23 0%,#141632 50%,#0d0f23 100%)}.splash-screen{z-index:9999;background:var(--bg);flex-direction:column;justify-content:center;align-items:center;gap:20px;display:flex;position:fixed;inset:0}.splash-logo{flex-direction:column;align-items:center;gap:10px;animation:1.6s ease-in-out infinite splash-pulse;display:flex}.splash-logo-img{object-fit:cover;border-radius:18px;width:72px;height:72px;box-shadow:0 8px 32px #0000002e}.splash-title{color:var(--primary);letter-spacing:-.5px;font-size:26px;font-weight:800}.splash-subtitle{color:var(--text-muted);letter-spacing:.08em;text-transform:uppercase;font-size:13px}.splash-dots{gap:8px;margin-top:4px;display:flex}.splash-dot{background:var(--primary);opacity:.35;border-radius:50%;width:7px;height:7px;animation:1.2s ease-in-out infinite splash-dot-bounce}.splash-dot:nth-child(2){animation-delay:.2s}.splash-dot:nth-child(3){animation-delay:.4s}.splash-bar{background:var(--border);border-radius:2px;width:140px;height:3px;margin-top:8px;overflow:hidden}.splash-bar-fill{background:var(--primary);border-radius:2px;height:100%;animation:2.5s ease-out forwards splash-progress}@keyframes splash-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.88;transform:scale(1.04)}}@keyframes splash-dot-bounce{0%,to{opacity:.35;transform:translateY(0)}50%{opacity:1;transform:translateY(-6px)}}@keyframes splash-progress{0%{width:0%}60%{width:85%}to{width:100%}}.app{width:100%;max-width:520px;min-height:100dvh;margin:0 auto;padding-bottom:100px}.main-content{width:100%}.hdr{color:#fff;z-index:200;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-radius:0 0 24px 24px;padding:0 1.25rem;transition:background .3s;position:sticky;top:0;box-shadow:0 4px 20px #667eea66}.hdr-inner{height:var(--hdr-h);justify-content:space-between;align-items:center;display:flex}.hdr-brand{flex-shrink:0;align-items:center;gap:.75rem;display:flex}.hdr-logo{border-radius:20%;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:42px;display:flex}.hdr-logo-img{object-fit:contain;border-radius:20%;width:100%;height:100%}.hdr-sub{opacity:.8;margin-top:1px;font-size:.72rem;font-weight:500}.hdr-actions{flex-shrink:0;align-items:center;gap:.5rem;display:flex}.stats-bar{color:var(--text-secondary);background:#667eea14;border-bottom:1px solid #667eea1a;justify-content:center;gap:1.5rem;padding:.4rem 1rem;font-size:.78rem;display:flex}.stats-bar b{color:var(--primary);font-weight:700}.locale-toggle{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0000000d;border-radius:20px;gap:2px;padding:3px;display:flex}.locale-btn{color:#ffffffb3;cursor:pointer;letter-spacing:.04em;background:0 0;border:none;border-radius:16px;padding:4px 10px;font-size:.75rem;font-weight:700;transition:all .2s}.locale-btn.active{background:var(--surface);color:var(--primary);box-shadow:0 2px 8px #00000026}.locale-btn:active{transform:scale(.92)}.hdr-icon-btn{color:#4b4664e6;cursor:pointer;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0000000f;border:none;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;transition:all .2s;display:flex}.hdr-icon-btn:active{transform:scale(.88)}.hdr-icon-btn.active{color:var(--primary);background:#fffffff2}.panel-open{opacity:1;max-height:800px}.trans-wrap,.settings-wrap{-webkit-backdrop-filter:blur(20px);background:#ffffffb8;border:1px solid #667eea1f;border-radius:20px;margin:.75rem 1rem;padding:1.25rem;animation:.35s cubic-bezier(.25,.46,.45,.94) panelIn;box-shadow:0 8px 32px #00000014,0 1px 2px #0000000a,inset 0 1px #fff9}[data-theme=dark] .trans-wrap,[data-theme=dark] .settings-wrap{background:#1e2236c7;border:1px solid #667eea26;box-shadow:0 8px 32px #0000004d,inset 0 1px #ffffff0d}@keyframes panelIn{0%{opacity:0;transform:translateY(-12px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.trans-header{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}.trans-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;font-size:.8rem;font-weight:700}.trans-row{align-items:center;gap:.5rem;margin-bottom:.6rem;display:flex}.trans-arrow{color:var(--text-muted);flex-shrink:0}.trans-lang-select{border-radius:var(--radius-xs);border:1.5px solid var(--border);background:var(--bg);color:var(--text);cursor:pointer;appearance:none;outline:none;flex:1;padding:.45rem .6rem;font-size:.85rem;font-weight:600;transition:border-color .2s}.trans-lang-select:focus{border-color:var(--primary)}.trans-input{border-radius:var(--radius-xs);border:1.5px solid var(--border);background:var(--bg);width:100%;color:var(--text);resize:none;outline:none;margin-bottom:.6rem;padding:.65rem .85rem;font-family:inherit;font-size:.95rem;transition:border-color .2s}.trans-input:focus{border-color:var(--primary)}.trans-input::placeholder{color:var(--text-muted)}.mic-btn{transition:all .2s}.mic-btn.recording{animation:1s infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.trans-submit-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#007aff 0%,#0056cc 100%);border:none;border-radius:12px;justify-content:center;align-items:center;gap:.5rem;width:100%;padding:.75rem 1rem;font-size:1rem;font-weight:600;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex;box-shadow:0 4px 16px #007aff59,inset 0 1px #ffffff26}.trans-submit-btn:active{background:linear-gradient(135deg,#0056cc 0%,#049 100%);transform:scale(.97);box-shadow:0 2px 8px #007aff40,inset 0 1px #ffffff1a}.trans-submit-btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:none;background:linear-gradient(135deg,#a0a0a0 0%,gray 100%);transform:none}.trans-spinner{border:2px solid #fff6;border-top-color:#fff;border-radius:50%;flex-shrink:0;width:16px;height:16px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.trans-result-box{background:linear-gradient(135deg, var(--primary-soft), transparent);border-radius:var(--radius-xs);border:1.5px solid var(--border-light);margin-top:.75rem;padding:.85rem}.trans-result-lo{color:var(--primary);margin-bottom:.6rem;font-size:1.25rem;font-weight:700;line-height:1.4}.trans-result-actions{gap:.5rem;display:flex}.trans-play-btn,.trans-action-btn{border:1.5px solid var(--border);background:var(--surface);color:var(--text-secondary);cursor:pointer;border-radius:20px;align-items:center;gap:.35rem;padding:0 1.1rem;font-size:.78rem;font-weight:600;transition:all .2s;display:flex}.trans-play-btn:hover,.trans-action-btn:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-soft)}.trans-history{border-top:1px solid var(--border);margin-top:.85rem;padding-top:.75rem}.trans-history-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.5rem;font-size:.75rem;font-weight:700}.trans-history-item{border-radius:var(--radius-xs);background:var(--bg);cursor:pointer;align-items:center;gap:.5rem;margin-bottom:.35rem;padding:.45rem .6rem;transition:background .2s;display:flex;position:relative}.trans-history-item:active{background:var(--primary-soft)}.trans-history-from{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:.82rem;overflow:hidden}.trans-history-arrow{color:var(--text-muted);flex-shrink:0;font-size:.75rem}.trans-history-to{color:var(--primary);white-space:nowrap;text-overflow:ellipsis;flex-shrink:0;max-width:120px;font-size:.88rem;font-weight:700;overflow:hidden}.history-del-btn{color:var(--text-muted);cursor:pointer;opacity:0;background:0 0;border:none;border-radius:6px;flex-shrink:0;margin-left:auto;padding:2px 6px;font-size:1rem;transition:opacity .15s,color .15s}.trans-history-item:hover .history-del-btn{opacity:1}.history-del-btn:hover{color:var(--danger,#ef4444);background:#ef44441a}.settings-section{margin-bottom:.85rem}.settings-section:last-child{margin-bottom:0}.settings-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.5rem;font-size:.75rem;font-weight:700}.lang-chips{flex-wrap:wrap;gap:.4rem;display:flex}.lang-chip{color:var(--text-secondary);cursor:pointer;background:#667eea14;border:none;border-radius:22px;align-items:center;gap:.3rem;padding:.45rem .9rem;font-size:.8rem;font-weight:500;transition:all .2s;display:inline-flex}[data-theme=dark] .lang-chip{background:#667eea26}.lang-chip:hover{color:var(--text);background:#667eea26}.lang-chip.active{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);font-weight:600;box-shadow:0 2px 8px #667eea4d}.lang-chip:active{transform:scale(.95)}.search-area{display:none!important}.search-box{background:var(--surface);box-shadow:var(--shadow);border:2px solid #0000;border-radius:18px;align-items:center;gap:.6rem;padding:0 .85rem;transition:all .25s;display:flex}.search-box:focus-within{border-color:var(--primary);box-shadow:0 0 0 4px var(--primary-glow), var(--shadow)}.search-icon{color:var(--text-muted);flex-shrink:0}.search-input{color:var(--text);background:0 0;border:none;outline:none;flex:1;padding:.85rem 0;font-family:inherit;font-size:.95rem}.search-input::placeholder{color:var(--text-muted)}.search-clear{background:var(--bg-secondary);width:26px;height:26px;color:var(--text-muted);cursor:pointer;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:all .2s;display:flex}.search-clear:hover{background:var(--danger);color:#fff}.search-clear:active{transform:scale(.88)}.tab-bar{-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:6px;padding:.75rem 1rem 0;display:flex;overflow-x:auto}.tab-bar::-webkit-scrollbar{display:none}.tab-btn{background:var(--surface);color:var(--text-secondary);cursor:pointer;box-shadow:var(--shadow);white-space:nowrap;letter-spacing:.01em;border:none;border-radius:20px;flex-shrink:0;align-items:center;gap:.4rem;padding:.55rem 1rem;font-size:.85rem;font-weight:700;transition:all .25s;display:inline-flex}.tab-btn:active{transform:scale(.95)}.tab-btn.active{background:var(--primary);color:#fff;box-shadow:0 4px 16px var(--primary-glow);transform:scale(1.02)}.tab-badge{min-width:18px;height:18px;color:inherit;background:#ffffff4d;border-radius:9px;justify-content:center;align-items:center;padding:0 4px;font-size:.68rem;font-weight:800;display:inline-flex}.tab-btn:not(.active) .tab-badge{background:var(--primary-soft);color:var(--primary)}.cats-scroll{-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:8px;padding:.6rem 1rem .5rem;display:flex;overflow-x:auto}.cat-pill{border:1.5px solid var(--border);background:var(--surface);color:var(--text-secondary);cursor:pointer;white-space:nowrap;border-radius:16px;flex-shrink:0;align-items:center;gap:.3rem;padding:.4rem .9rem;font-size:.8rem;font-weight:600;transition:all .2s;display:inline-flex;box-shadow:0 2px 8px #0000000a}.cat-pill:active{transform:scale(.95)}.cat-pill.active{background:var(--primary);color:#fff;box-shadow:0 4px 12px var(--primary-glow);border-color:#0000}.cat-locked{opacity:.5;text-decoration:line-through}.cat-loading{opacity:.6}.cat-count{opacity:.7;font-size:.7rem;font-weight:500}.phrase-list{padding:.5rem var(--page-gutter) 2rem;flex-direction:column;gap:.75rem;display:flex}.phrase-card{background:linear-gradient(135deg,#fff 0%,#f8f9ff 100%);border:1px solid #667eea1a;border-radius:18px;min-height:88px;padding:1rem 1rem .95rem;transition:all .25s;animation:.3s both cardIn;box-shadow:0 2px 8px #0000000a,0 4px 16px #667eea14}[data-theme=dark] .phrase-card{background:linear-gradient(135deg,#1a1e3a 0%,#202448 100%);border:1px solid #667eea26;box-shadow:0 2px 8px #0003,0 4px 16px #0000004d}@keyframes cardIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.phrase-card:active{box-shadow:var(--shadow-md);transform:scale(.985)}.phrase-card.playing{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow), var(--shadow-md);background:var(--surface-hover)}.card-lao-row{align-items:center;gap:.6rem;margin-bottom:.75rem;display:flex}.card-lao{color:var(--primary);cursor:pointer;letter-spacing:.01em;flex:1;min-width:0;font-size:1.4rem;font-weight:800;line-height:1.35;transition:opacity .2s}.card-lao:hover{opacity:.75}.card-lao:active{opacity:.5}.card-roman{color:var(--text-secondary);margin-top:-.25rem;margin-bottom:.25rem;padding:2px 0;font-size:.85rem;font-style:italic}.card-actions{flex-shrink:0;gap:.4rem;display:flex}.card-play-btn,.card-fav-btn{cursor:pointer;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;transition:all .2s;display:flex}.card-play-btn{background:var(--primary);color:#fff;box-shadow:0 3px 12px var(--primary-glow)}.card-play-btn.active{background:var(--primary-dark);animation:1s infinite playPulse}@keyframes playPulse{0%,to{box-shadow:0 3px 12px var(--primary-glow)}50%{box-shadow:0 3px 24px var(--primary-glow), 0 0 0 6px var(--primary-soft)}}.card-play-btn:active,.card-fav-btn:active{transform:scale(.85)}.card-fav-btn{background:var(--bg-secondary);color:var(--text-muted)}.card-fav-btn.active{color:var(--fav-color);background:#f43f5e1a}.card-share-btn{background:var(--bg-secondary);color:var(--text-muted);cursor:pointer;border:none;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;transition:all .2s;display:flex}.card-share-btn:hover{color:var(--primary);background:#4f46e51f}.card-share-btn:active{transform:scale(.85)}.card-trans{flex-direction:column;gap:.3rem;margin-bottom:.5rem;display:flex}.card-trans-item{align-items:baseline;gap:.5rem;display:flex}.trans-lang-label{letter-spacing:.06em;opacity:.75;border-radius:6px;flex-shrink:0;padding:1px 6px;font-size:.65rem;font-weight:800}.tag-zh .trans-lang-label{color:#dc2626;background:#dc26261f}.tag-en .trans-lang-label{color:#2563eb;background:#2563eb1f}.tag-th .trans-lang-label{color:#9333ea;background:#9333ea1f}.tag-vi .trans-lang-label{color:#ca8a04;background:#ca8a041f}.tag-lo .trans-lang-label{color:var(--primary);background:#667eea1f}.trans-text{color:var(--text);word-break:break-word;font-size:.92rem;line-height:1.45}.card-category{color:var(--text-muted);background:var(--bg-secondary);border-radius:8px;align-items:center;gap:.3rem;width:fit-content;margin-top:.25rem;padding:.2rem .6rem;font-size:.72rem;font-weight:600;display:inline-flex}.cat-hot-count{color:var(--warning);font-weight:700}.empty-state{text-align:center;padding:3.5rem 1rem;animation:.3s cardIn}.empty-icon{opacity:.5;filter:grayscale(.3);margin-bottom:.85rem;font-size:3.5rem}.empty-state p{color:var(--text-secondary);margin:.3rem 0;font-size:.9rem;font-weight:500}.empty-title{color:var(--text)!important;font-size:1rem!important;font-weight:700!important}.empty-sub{opacity:.7;font-size:.82rem!important}.clear-history-btn{border:1.5px solid var(--danger);color:var(--danger);cursor:pointer;background:0 0;border-radius:20px;margin-top:.75rem;padding:.45rem 1rem;font-size:.8rem;font-weight:600;transition:all .2s}.clear-history-btn:hover{background:#ef444414}.clear-history-btn:active{transform:scale(.95)}.loading-spinner{border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;width:36px;height:36px;margin:0 auto .75rem;animation:.8s linear infinite spin}.toast{color:#fff;z-index:9999;white-space:nowrap;pointer-events:none;background:linear-gradient(135deg,#1a1d3b,#2d3260);border-radius:24px;align-items:center;gap:.5rem;padding:.65rem 1.25rem;font-size:.85rem;font-weight:600;animation:.25s cubic-bezier(.4,0,.2,1) toastIn;display:flex;position:fixed;bottom:28px;left:50%;transform:translate(-50%);box-shadow:0 8px 32px #00000059}[data-theme=dark] .toast{background:linear-gradient(135deg,#2d3260,#3d4480)}@keyframes toastIn{0%{opacity:0;transform:translate(-50%)translateY(16px)scale(.9)}to{opacity:1;transform:translate(-50%)translateY(0)scale(1)}}@media (width<=480px){:root{--page-gutter:.75rem;--hdr-h:58px}.app{width:100%;max-width:100%}.hdr{border-radius:0 0 16px 16px;padding-left:.75rem;padding-right:.75rem}.hdr-inner{gap:.5rem}.hdr-brand{gap:.4rem}.hdr-logo-img{height:32px!important}.locale-btn{min-height:36px;padding:4px 8px}.hdr-icon-btn{width:40px;height:40px}.tab-bar{gap:8px;padding-top:.65rem}.tab-btn{min-height:44px;padding:.6rem .95rem;font-size:.84rem}.cat-pill{min-height:40px;padding:.5rem .85rem}.card-lao{font-size:1.2rem}.card-actions{gap:.35rem}.card-play-btn,.card-fav-btn{width:44px;height:44px}.trans-wrap,.settings-wrap{margin:.5rem var(--page-gutter)}.search-area,.tab-bar,.cats-scroll,.phrase-list{padding-left:var(--page-gutter);padding-right:var(--page-gutter)}.phrase-card{border-radius:16px;padding:.9rem .9rem .8rem}.page{padding-left:var(--page-gutter);padding-right:var(--page-gutter)}.quick-translate-card{margin:.75rem var(--page-gutter);padding:.95rem}.quick-translate-input{font-size:16px}.quick-translate-btn{min-height:44px;padding:.6rem .95rem}}@media (width>=600px){.app{width:100%;max-width:520px;padding-top:1rem}.hdr{border-radius:var(--radius);margin:.5rem .75rem;position:static}}@media (width>=768px){::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--primary)}}@media print{.hdr{box-shadow:none}.hdr-actions,.toast{display:none}.phrase-card{break-inside:avoid}}.modal-box{background:var(--surface);border-radius:var(--radius);width:100%;max-width:320px;box-shadow:var(--shadow);padding:1.5rem;position:relative}.login-input{border:2px solid var(--border);border-radius:var(--radius-xs);background:var(--bg);width:100%;color:var(--text);box-sizing:border-box;outline:none;padding:.65rem .85rem;font-size:.95rem}.login-btn{background:var(--primary);color:#fff;border-radius:var(--radius-xs);cursor:pointer;border:none;width:100%;padding:.65rem;font-size:.95rem;font-weight:600}.login-btn:active{transform:scale(.97)}.fav-section-label{color:var(--text-secondary);align-items:center;gap:8px;padding:8px 4px 4px;font-size:12px;font-weight:600;display:flex}.fav-section-label .fav-count{background:var(--primary);color:#fff;border-radius:10px;padding:0 6px;font-size:10px}.app{padding-top:env(safe-area-inset-top,0px);padding-left:env(safe-area-inset-left,0px);padding-right:env(safe-area-inset-right,0px);padding-bottom:calc(80px + env(safe-area-inset-bottom,0px))}body{overscroll-behavior-y:contain;min-height:100vh}.visit-counter{text-align:center;color:var(--text-secondary);background:var(--surface);border:1px solid var(--border);border-radius:8px;margin:0 12px 8px;padding:10px;font-size:13px}.bottom-nav{z-index:500;padding-bottom:env(safe-area-inset-bottom,0px);box-sizing:border-box;-webkit-backdrop-filter:saturate(180%)blur(20px);box-shadow:0 -1px 0 var(--border-light);background:#ffffffeb;justify-content:space-around;align-items:center;transition:transform .3s cubic-bezier(.32,.72,0,1);display:flex;position:fixed;bottom:0;left:0;right:0;overflow:hidden;transform:translateY(0)}.nav-hidden{transform:translateY(100%)}.nav-visible{transform:translateY(0)}.nav-item{cursor:pointer;color:var(--text-muted);-webkit-tap-highlight-color:transparent;touch-action:manipulation;background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:2px;padding:4px;font-family:inherit;font-size:11px;transition:color .2s,transform .15s;display:flex;position:relative}.nav-item:active{color:var(--primary);transform:scale(.92)}.nav-item.active:after{content:"";background:var(--primary);border-radius:2px;width:20px;height:3px;position:absolute;bottom:6px;left:50%;transform:translate(-50%)}.nav-item svg{flex-shrink:0;width:22px;height:22px}.nav-item span{letter-spacing:.02em;font-weight:600}.toast{bottom:calc(60px + env(safe-area-inset-bottom,0px));-webkit-backdrop-filter:blur(12px)}.hdr-icon-btn{will-change:transform;min-width:40px;min-height:40px}.tab-btn{min-height:38px;padding:6px 14px}.cat-pill{min-height:34px;padding:5px 12px;font-size:13px}.phrase-card{cursor:pointer;-webkit-tap-highlight-color:var(--primary-soft);transition:background .15s}.cats-scroll::-webkit-scrollbar{display:none}.cats-scroll{scrollbar-width:none;-ms-overflow-style:none}.trans-input,.login-input{font-size:16px!important}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important}}@media (height<=500px) and (orientation:landscape){.app{padding-top:0}.bottom-nav{border-radius:0;width:100%;left:0;right:0}.app{padding-bottom:20px}}@media (width>=600px){.bottom-nav{border-radius:22px 22px 0 0;width:min(100%,520px);left:50%;right:auto;transform:translate(-50%)}.app{padding-bottom:var(--pad-bottom,100px)}}[data-theme=dark] .bottom-nav{background:#1a1e3af2;border-top-color:#667eea2e}[data-theme=dark] .cat-pill{background:var(--surface);color:var(--text-secondary);border-color:var(--border)}[data-theme=dark] .cat-pill.active{background:var(--primary);color:#fff}[data-theme=dark] .search-box{background:var(--surface);border-color:var(--border)}[data-theme=dark] .search-input{color:var(--text);background:0 0}[data-theme=dark] mark{color:var(--primary);background:#818cf840}[data-theme=dark] .tab-badge{background:var(--primary);color:#fff}mark{border-radius:2px;padding:0 1px;font-style:normal}.fav-sort-bar{flex-wrap:wrap;align-items:center;gap:6px;margin-bottom:12px;display:flex}.apple-export-btn{background:var(--primary);color:#fff;border-radius:var(--radius-sm);cursor:pointer;letter-spacing:-.01em;border:none;justify-content:center;align-items:center;gap:.5rem;width:100%;margin:.5rem 1rem .25rem;padding:.7rem 1.25rem;font-family:inherit;font-size:.9rem;font-weight:600;transition:all .2s;display:flex}.export-fav-btn{background:var(--primary);color:#fff;border-radius:var(--radius-xs);cursor:pointer;background:var(--primary);cursor:pointer;border:none;border-radius:12px;justify-content:center;align-items:center;gap:8px;width:100%;margin-bottom:8px;padding:10px 16px;font-family:inherit;font-size:14px;font-weight:600;transition:all .2s;display:flex}.fav-sort-row{flex-wrap:wrap;gap:6px;display:flex}.trans-result-box{background:var(--surface);border:1px solid var(--border);border-radius:16px;margin:12px 0;padding:16px 20px;animation:.2s slideDown}.trans-result-actions{align-items:center;gap:8px;display:flex}.trans-play-btn,.trans-action-btn{border:1.5px solid var(--border);background:var(--surface);color:var(--text-secondary);cursor:pointer;border-radius:10px;justify-content:center;align-items:center;gap:6px;min-width:44px;min-height:44px;padding:0 14px;font-family:inherit;transition:all .18s;display:flex}.trans-play-btn:hover,.trans-action-btn:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-soft);transform:translateY(-1px)}.trans-play-btn:active,.trans-action-btn:active{transform:scale(.94)}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.phrase-actions{flex-shrink:0;align-items:center;gap:6px;display:flex}.play-btn,.fav-btn{border:1.5px solid var(--border);background:var(--surface);color:var(--text-secondary);cursor:pointer;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;padding:0;transition:all .18s;display:flex}.play-btn:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-soft);transform:translateY(-1px)}.play-btn:active,.fav-btn:active{transform:scale(.9)}.fav-btn.active{background:var(--primary);border-color:var(--primary);color:#fff}[data-theme=dark] .play-btn,[data-theme=dark] .fav-btn{background:var(--surface);color:var(--text-secondary);border-color:#667eea4d}.admin-standalone{display:none!important}.admin-login-wrap{background:var(--surface);border:1px solid var(--border);border-radius:20px;width:100%;max-width:400px;padding:40px 36px;box-shadow:0 20px 60px #0000001a}.admin-login-wrap h2{text-align:center;color:var(--text);margin-bottom:28px;font-size:20px}.admin-login-wrap .login-input{border:1.5px solid var(--border);background:var(--bg);width:100%;color:var(--text);box-sizing:border-box;border-radius:12px;margin-bottom:16px;padding:14px 16px;font-family:inherit;font-size:15px}.admin-login-wrap .login-btn{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:12px;width:100%;padding:14px;font-family:inherit;font-size:15px;font-weight:600;transition:transform .15s}.admin-login-wrap .login-btn:active{transform:scale(.97)}.fav-sort-bar{flex-wrap:wrap;gap:6px;margin-bottom:12px;display:flex}.fav-sort-btn{border:1.5px solid var(--border);background:var(--surface);color:var(--text-secondary);cursor:pointer;border-radius:8px;padding:5px 12px;font-family:inherit;font-size:12px;transition:all .2s}.fav-sort-btn:active{transform:scale(.95)}[data-theme=dark] .trans-result-box{background:#1a1e3acc;border-color:#667eea33}[data-theme=dark] .trans-result-lo{color:#818cf8e6}[data-theme=dark] .toast{color:var(--text);background:#1a1e3af2;border-color:#667eea33}[data-theme=dark] .bottom-nav{-webkit-backdrop-filter:saturate(180%)blur(20px);background:#1a1e3af2;border-top-color:#667eea26}[data-theme=dark] .apple-export-btn{background:var(--primary);color:#fff;border-radius:var(--radius-sm);cursor:pointer;letter-spacing:-.01em;border:none;justify-content:center;align-items:center;gap:.5rem;width:100%;margin:.5rem 1rem .25rem;padding:.7rem 1.25rem;font-family:inherit;font-size:.9rem;font-weight:600;transition:all .2s;display:flex}.apple-export-btn:hover{opacity:.88}.apple-export-btn:active{opacity:.65}.play-btn,.fav-btn{border:1px solid var(--border-light);background:var(--surface);color:var(--text-secondary)}.play-btn:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-soft)}.fav-btn.active{border-color:var(--fav-color);color:var(--fav-color);background:#ff2d5514}.export-fav-btn{background:var(--primary);color:#fff;border-radius:var(--radius-xs);cursor:pointer;background:linear-gradient(135deg,#667eeae6,#764ba2e6);border:1px solid #667eea66;justify-content:center;align-items:center;gap:.5rem;width:100%;margin-bottom:.5rem;padding:.75rem 1rem;font-family:inherit;font-size:.85rem;font-weight:600;transition:all .2s;display:flex}[data-theme=dark] .fav-sort-btn{color:#fff9;background:#1e233ccc;border-color:#667eea40}[data-theme=dark] .fav-sort-btn.active{color:#fff;background:#667eeacc;border-color:#667eea80}.phrase-card:active{background:var(--primary-soft)}.cats-scroll{gap:8px;padding:4px 16px}.search-input{min-height:44px;font-size:16px}.empty-state{text-align:center;padding:48px 20px}.empty-state .empty-icon{margin-bottom:12px;font-size:48px}.empty-state p{color:var(--text-secondary);font-size:14px}@keyframes shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}.skeleton-card{pointer-events:none;animation:none}.skeleton-line{background:linear-gradient(90deg, var(--border) 25%, var(--surface-hover) 50%, var(--border) 75%);background-size:800px 100%;border-radius:6px;animation:1.5s infinite shimmer;display:block}[data-theme=dark] .skeleton-line{background:linear-gradient(90deg,#667eea14 25%,#667eea26 50%,#667eea14 75%) 0 0/800px 100%}.skeleton-list{flex-direction:column;gap:8px;padding:0 16px;display:flex}.loading-spinner,.trans-history-search{display:none!important}.announcement-bar{background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:12px;margin:8px 12px;padding:12px 14px;font-size:13px;line-height:1.7}.announcement-title{color:var(--primary);margin-bottom:6px;font-size:14px;font-weight:700}.announcement-body{color:var(--text-secondary);margin-bottom:4px;font-size:12px}.announcement-section{color:var(--text);margin-top:4px;margin-bottom:2px;font-size:12px;font-weight:700}.announcement-item{color:var(--text-secondary);padding-left:8px;font-size:12px;line-height:1.6}.announcement-item a{color:var(--primary);font-weight:500;text-decoration:none}.announcement-item a:hover{text-decoration:underline}.quick-translate-card{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-radius:16px;margin:.75rem;padding:1rem}.quick-translate-title{margin-bottom:.75rem;font-size:.9rem;font-weight:600}.quick-translate-input-row{gap:.5rem;display:flex}.quick-translate-input{color:#333;background:#ffffffe6;border:none;border-radius:10px;flex:1;padding:.6rem .8rem;font-size:.9rem}.quick-translate-btn{color:#667eea;cursor:pointer;background:#fff;border:none;border-radius:10px;padding:.6rem 1rem;font-weight:600}.quick-translate-result{background:#ffffff26;border-radius:10px;justify-content:space-between;align-items:center;margin-top:.75rem;padding:.75rem;display:flex}.lo-text{font-size:1.1rem;font-weight:500}.copy-btn{cursor:pointer;opacity:.8;background:0 0;border:none;font-size:1.2rem}.quick-ai-btn{color:#ffffffb3;cursor:pointer;white-space:nowrap;background:#ffffff1a;border:1.5px solid #ffffff59;border-radius:10px;padding:.55rem .75rem;font-size:.8rem;font-weight:700;transition:all .2s}.quick-ai-btn.active{color:#fff;background:#ffffff40;border-color:#ffffffb3;box-shadow:0 0 12px #ffffff4d}.quick-result-local,.quick-result-ai{flex-wrap:wrap;flex:1;align-items:center;gap:8px;display:flex}.quick-result-sep{color:#fff9;font-size:1rem}.quick-result-en{color:#ffffffa6;font-size:.85rem;font-style:italic}.quick-result-tag{color:#ffffffe6;background:#fff3;border-radius:20px;margin-left:auto;padding:2px 8px;font-size:.7rem;font-weight:700}.quick-no-result{color:#ffffff8c;text-align:center;margin-top:.6rem;font-size:.8rem;font-style:italic}.search-history-dropdown{background:var(--surface);border:1.5px solid var(--border);z-index:200;border-radius:14px;margin-top:6px;position:absolute;top:100%;left:0;right:0;overflow:hidden;box-shadow:0 8px 24px #0000001f}.search-history-header{color:var(--text-muted);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:10px 14px;font-size:.78rem;display:flex}.clear-history-btn{color:var(--primary);cursor:pointer;background:0 0;border:none;font-size:.78rem}.search-history-item{cursor:pointer;color:var(--text);align-items:center;gap:10px;padding:10px 14px;font-size:.9rem;transition:background .15s;display:flex}.search-history-item:hover{background:var(--bg-secondary)}.history-icon{opacity:.6;font-size:.85rem}.search-clear-btn{width:26px;height:26px;color:var(--text-muted);cursor:pointer;z-index:10;background:#fffc;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:.75rem;display:flex;position:absolute;top:50%;right:148px;transform:translateY(-50%)}.quick-results-list{flex-direction:column;gap:8px;margin-top:.75rem;display:flex}.quick-result-item{-webkit-backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #ffffff26;border-radius:14px;flex-direction:column;gap:6px;padding:.85rem .95rem;display:flex}.quick-result-main{align-items:baseline;gap:10px;display:flex}.quick-result-lo{color:var(--primary);font-size:1.3rem;font-weight:800}.quick-result-roman{color:#f5a623;text-transform:uppercase;font-size:.78rem;font-style:italic;font-weight:600}.quick-result-details{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.quick-result-zh{color:var(--text);font-size:.9rem;font-weight:600}.quick-result-en{color:var(--text-secondary);font-size:.85rem}.quick-result-source{color:var(--primary);background:#4f46e51f;border-radius:20px;padding:2px 8px;font-size:.68rem;font-weight:600}.quick-result-actions{gap:8px;margin-top:4px;display:flex}.quick-action-btn{cursor:pointer;background:#ffffff26;border:none;border-radius:10px;justify-content:center;align-items:center;width:34px;height:34px;font-size:.9rem;transition:all .2s;display:flex}.quick-action-btn:hover{background:#ffffff40;transform:scale(1.05)}.quick-action-btn.active{background:#ff000026}.daily-word-card{color:#fff;text-align:center;background:linear-gradient(135deg,#11998e 0%,#38ef7d 100%);border-radius:16px;margin:.75rem;padding:1.25rem}.daily-word-label{opacity:.9;margin-bottom:.5rem;font-size:.8rem}.daily-word-content{justify-content:center;align-items:center;gap:1rem;display:flex}.daily-word-zh{font-size:1.5rem;font-weight:700}.daily-word-lo{font-size:1.3rem}.daily-word-play{cursor:pointer;background:#fff3;border:none;border-radius:50%;width:36px;height:36px;font-size:1rem}.business-trip-selector{background:#f8f9fa;padding:.75rem}.scene-tabs{gap:.5rem;padding-bottom:.5rem;display:flex;overflow-x:auto}.scene-tab{white-space:nowrap;cursor:pointer;background:#fff;border:1px solid #e0e0e0;border-radius:20px;padding:.5rem .8rem;font-size:.75rem}.scene-tab.active{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-color:#0000}.business-trip-list{padding:.75rem}.business-trip-list .phrase-card{cursor:pointer;background:#fff;border-radius:12px;justify-content:space-between;align-items:center;margin-bottom:.6rem;padding:.9rem;transition:transform .15s;display:flex;box-shadow:0 2px 8px #0000000f}.business-trip-list .phrase-card:active{transform:scale(.98)}.business-trip-list .phrase-zh{color:#333;font-size:.95rem;font-weight:500}.business-trip-list .phrase-lo{color:#667eea;text-align:center;flex:1;margin:0 .5rem;font-size:.9rem}.business-trip-list .phrase-play{cursor:pointer;background:#f0f0f0;border:none;border-radius:50%;width:32px;height:32px;font-size:.9rem}.quiz-start,.quiz-result{text-align:center;flex-direction:column;align-items:center;padding:28px 20px 20px;display:flex}.quiz-start h2,.quiz-result h2{margin-top:8px;margin-bottom:12px;font-size:24px}.quiz-icon{margin-bottom:16px;font-size:64px}.result-emoji{margin-bottom:20px;font-size:72px;animation:.5s bounce}.flashcard-start h2{margin-top:16px}.quiz-start h2,.quiz-result h2{margin-top:12px}@keyframes bounce{0%,to{transform:scale(1)}50%{transform:scale(1.2)}}.quiz-info{color:var(--text-muted);margin-bottom:20px}.quiz-count-selector{justify-content:center;align-items:center;gap:10px;margin:16px 0;display:flex}.quiz-count-selector select{border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:8px;padding:8px 16px;font-size:16px}.start-btn{background:var(--primary);color:#fff;border-radius:var(--radius);cursor:pointer;border:none;padding:14px 40px;font-size:18px}.result-stats{gap:32px;margin:24px 0;display:flex}.stat{flex-direction:column;align-items:center;display:flex}.stat-num{color:var(--primary);font-size:36px;font-weight:700}.stat-label{color:var(--text-muted);flex-direction:column;align-items:center;gap:4px;margin-top:16px;font-size:14px;display:flex}.label-emoji{font-size:20px;line-height:1}.result-mini-bar{flex-wrap:wrap;align-items:center}.result-mini-score,.result-mini-accuracy{line-height:1}.result-mini-delta{white-space:nowrap}.wrong-answers{text-align:left;width:100%;max-width:400px;margin-top:20px}.wrong-list{margin-top:12px}.wrong-item{background:var(--hot-bg);border:1px solid var(--hot-border);border-radius:var(--radius-sm);margin-bottom:8px;padding:12px}.wrong-q{margin-bottom:4px;font-weight:700}.wrong-a{color:var(--success);font-size:14px}.restart-btn{background:var(--primary);color:#fff;border-radius:var(--radius);cursor:pointer;border:none;margin-top:20px;padding:14px 32px;font-size:16px}.quiz-container{padding:16px}.quiz-header{margin-bottom:24px}.quiz-progress-info{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.quiz-progress-bar{background:var(--border);border-radius:3px;height:6px;overflow:hidden}.quiz-progress-fill{background:var(--primary);border-radius:3px;height:100%;transition:width .3s}.quiz-progress{color:var(--text-muted);font-size:14px}.quiz-score{color:var(--primary);font-weight:700}.quiz-question{text-align:center;margin-bottom:24px}.quiz-question h3{margin-bottom:8px;font-size:28px}.quiz-question p{color:var(--text-muted)}.play-main-btn{background:var(--primary);color:#fff;border-radius:var(--radius);cursor:pointer;border:none;margin:16px 0;padding:16px 32px;font-size:18px}.play-main-btn:hover{opacity:.9}.opt-zh{color:var(--text);font-size:16px;font-weight:500}.quiz-options{grid-template-columns:1fr 1fr;gap:12px;display:grid}.quiz-option{background:var(--surface);border:2px solid var(--border);border-radius:var(--radius);cursor:pointer;flex-direction:column;justify-content:center;align-items:center;gap:4px;min-height:70px;padding:12px 10px;font-size:16px;transition:all .2s;display:flex}.quiz-option:hover:not(:disabled),.quiz-option.selected{border-color:var(--primary);background:var(--primary-soft)}.quiz-option.correct{border-color:var(--success);background:#34c7591a}.quiz-option.wrong{border-color:var(--danger);background:#ef44441a}.quiz-option:disabled{cursor:default}.opt-lo{color:var(--primary);font-size:16px;font-weight:600}.opt-roman{color:var(--text-secondary);font-size:12px}.opt-en{color:var(--text-muted);font-size:11px}.next-btn{background:var(--primary);color:#fff;border-radius:var(--radius);cursor:pointer;border:none;width:100%;margin-top:20px;padding:16px;font-size:16px}.flashcard-start{text-align:center;flex-direction:column;justify-content:center;align-items:center;min-height:60vh;padding:20px;display:flex}.flashcard-icon{margin-bottom:24px;font-size:64px}.card-info{color:var(--text-muted);margin-bottom:20px}.flashcard-container{flex-direction:column;align-items:center;padding:16px;display:flex}.flashcard-header{justify-content:space-between;width:100%;margin-bottom:24px;display:flex}.card-progress{color:var(--text-muted);font-size:14px}.card-known{color:var(--success);font-weight:700}.flashcard{perspective:1000px;cursor:pointer;width:100%;max-width:340px;height:220px;margin-bottom:24px}.flashcard-front,.flashcard-back{backface-visibility:hidden;border-radius:var(--radius);width:100%;height:100%;box-shadow:var(--shadow-lg);justify-content:center;align-items:center;display:flex;position:absolute}.flashcard-back{background:linear-gradient(135deg, var(--primary) 0%, var(--primary-dark) 100%);color:#fff;transform:rotateY(180deg)}.flashcard.flipped .flashcard-front{transform:rotateY(180deg)}.flashcard.flipped .flashcard-back{transform:rotateY(0)}.card-content{text-align:center;padding:20px}.card-main{font-size:32px;font-weight:700}.card-hint{color:var(--text-muted);margin-top:16px;font-size:12px}.card-lo{font-size:28px;font-weight:700}.card-roman{color:var(--text-secondary);margin-top:6px;font-size:14px}.card-en{opacity:.8;margin-top:8px;font-size:16px}.flashcard-actions{gap:16px;width:100%;max-width:340px;display:flex}.know-btn,.unknown-btn{border-radius:var(--radius);cursor:pointer;border:none;flex:1;padding:14px;font-size:16px}.know-btn{background:var(--success);color:#fff}.unknown-btn{background:var(--danger);color:#fff}.flip-hint{color:var(--text-muted);margin-top:12px;font-size:12px}.flashcard-result{text-align:center;padding:28px 20px 20px}.flashcard-result h2{margin-top:8px;margin-bottom:16px}.unknown-review{text-align:left;margin-top:24px}.unknown-list{margin-top:12px}.unknown-item{background:var(--hot-bg);border-radius:var(--radius-sm);justify-content:space-between;margin-bottom:8px;padding:10px 12px;display:flex}.unknown-zh{font-weight:700}.unknown-lo{color:var(--primary)}.quiz-hint{color:var(--text-muted);text-align:center;margin-bottom:16px;font-size:14px}.result-section{margin-top:16px}.correct-answer-hint{text-align:center;border-radius:var(--radius-sm);background:#34c7591a;margin-bottom:12px;padding:12px}.flashcard{cursor:pointer;-webkit-user-select:none;user-select:none}.result-actions{flex-direction:column;gap:12px;width:100%;max-width:300px;margin-top:20px;display:flex}.result-actions button{width:100%}.clear-wrong-btn{background:var(--text-muted);color:#fff;border-radius:var(--radius);cursor:pointer;border:none;margin-top:8px;padding:10px 20px;font-size:14px}.toggle-all-btn{background:var(--surface);border:2px solid var(--border);color:var(--text);border-radius:var(--radius);cursor:pointer;width:100%;max-width:300px;margin:16px 0;padding:10px 20px;font-size:14px}.toggle-all-btn:hover{border-color:var(--primary);background:var(--primary-soft)}.result-tabs{gap:8px;margin:16px 0;display:flex}.result-tab{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;color:var(--text-secondary);flex:1;padding:10px 16px;font-size:14px}.result-tab.active{background:var(--primary);border-color:var(--primary);color:#fff}.result-tab:not(.active):hover{background:var(--primary-soft);border-color:var(--primary)}.saved-progress{background:var(--primary-soft);border:2px solid var(--primary);border-radius:var(--radius);text-align:center;margin-bottom:16px;padding:16px}.saved-progress p{margin:0 0 8px;font-weight:600}.progress-info{color:var(--text-secondary);font-size:13px;font-weight:400!important}.resume-btn{background:var(--primary);color:#fff;border-radius:var(--radius);cursor:pointer;border:none;margin-right:8px;padding:10px 20px;font-size:14px}.result-list{width:100%;max-width:400px;max-height:400px;margin:12px 0;overflow-y:auto}.result-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);text-align:left;margin-bottom:10px;padding:12px}.result-item.correct{border-left:4px solid var(--success)}.result-item.wrong{border-left:4px solid var(--danger)}.result-item-header{justify-content:space-between;margin-bottom:8px;display:flex}.result-item-num{color:var(--text-muted);font-size:12px}.result-item-status{font-size:16px}.result-item-q{margin-bottom:6px;font-size:15px;font-weight:600}.result-item-correct{color:var(--success);font-size:13px}.result-item-roman{color:var(--text-secondary);margin-top:4px;font-size:12px}.result-item-wrong{color:var(--danger);margin-top:4px;font-size:13px}.result-item-actions{margin-top:8px}.play-btn{background:var(--primary-soft);color:var(--primary);cursor:pointer;border:none;border-radius:6px;margin-top:8px;padding:6px 12px;font-size:12px}.play-btn:hover{background:var(--primary);color:#fff}.no-wrong{text-align:center;color:var(--success);padding:30px;font-size:16px}.clear-wrong-btn:hover{background:var(--danger)}.modal-overlay{z-index:1000;background:#000000b3;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.feedback-modal{background:var(--card-bg,#1a1a2e);border-radius:16px;width:100%;max-width:400px;max-height:85vh;padding:24px;position:relative;overflow-y:auto;box-shadow:0 20px 60px #0006}.modal-close{cursor:pointer;color:var(--text-secondary,#888);background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:24px;line-height:1;display:flex;position:absolute;top:12px;right:12px}.modal-close:hover{background:var(--border,#333)}.feedback-modal h2{color:var(--text,#fff);margin:0 0 4px;font-size:20px}.feedback-desc{color:var(--text-secondary,#888);margin:0 0 20px;font-size:14px}.feedback-type label,.feedback-field label{color:var(--text-secondary,#888);margin-bottom:8px;font-size:13px;display:block}.type-pills{flex-wrap:wrap;gap:8px;margin-bottom:16px;display:flex}.type-pill{border:1px solid var(--border,#444);color:var(--text,#fff);cursor:pointer;background:0 0;border-radius:20px;padding:6px 14px;font-size:13px;transition:all .2s}.type-pill.active{color:#fff;background:#4a90d9;border-color:#4a90d9}.type-pill:hover:not(.active){border-color:#4a90d9}.feedback-field{margin-bottom:16px}.feedback-field textarea{border:1px solid var(--border,#444);background:var(--input-bg,#252540);width:100%;color:var(--text,#fff);resize:vertical;box-sizing:border-box;border-radius:10px;padding:12px;font-family:inherit;font-size:14px}.feedback-field textarea:focus{border-color:#4a90d9;outline:none}.feedback-field input{border:1px solid var(--border,#444);background:var(--input-bg,#252540);width:100%;color:var(--text,#fff);box-sizing:border-box;border-radius:10px;padding:12px;font-size:14px}.feedback-field input:focus{border-color:#4a90d9;outline:none}.feedback-submit{color:#fff;cursor:pointer;background:#4a90d9;border:none;border-radius:10px;width:100%;margin-top:8px;padding:14px;font-size:16px;font-weight:600;transition:background .2s}.feedback-submit:hover:not(:disabled){background:#3a7bc8}.feedback-submit:disabled{opacity:.5;cursor:not-allowed}.feedback-success{text-align:center;padding:40px 20px}.success-icon{margin-bottom:16px;font-size:48px}.feedback-success h3{color:var(--text,#fff);margin:0 0 8px}.feedback-success p{color:var(--text-secondary,#888);margin:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.tab-content{animation:.3s ease-out fadeIn}.nav-item.active{transition:transform .2s;transform:scale(1.1)}.translate-section{background:var(--surface);border-bottom:1px solid var(--border);max-height:0;padding:0 12px;transition:max-height .3s ease-out,padding .3s ease-out;overflow:hidden}.translate-section.expanded{max-height:500px;padding:12px}.full-page{flex:1;padding-bottom:70px;overflow-y:auto}.hot-header,.fav-header,.official-header{background:var(--surface);border-bottom:1px solid var(--border);padding:12px 16px}.hot-title,.fav-title,.official-title{font-size:16px;font-weight:600}.tab-content{flex:1;min-height:calc(100vh - 120px);padding-bottom:70px;overflow-y:auto}.page{padding:0 var(--page-gutter);min-height:calc(100vh - 120px);padding-bottom:80px}.translate-page .trans-wrap{padding:1rem 0}.settings-page{padding:0 1rem 80px}.settings-section{background:var(--surface);box-shadow:var(--shadow);border-radius:16px;margin-bottom:.75rem;padding:1rem}.settings-section-title{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.75rem;font-size:.8rem;font-weight:700}.settings-row{flex-wrap:wrap;gap:8px;display:flex}.settings-lang-btn{border:1.5px solid var(--border);background:var(--bg);color:var(--text);cursor:pointer;border-radius:20px;padding:6px 14px;font-size:.85rem;font-weight:600;transition:all .2s}.settings-lang-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.settings-toggle-row{border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;padding:8px 0;display:flex}.settings-toggle-row:last-child{border-bottom:none}.toggle-btn{background:var(--bg-secondary);color:var(--text-secondary);cursor:pointer;border:none;border-radius:12px;padding:4px 14px;font-size:.8rem;font-weight:600;transition:all .2s}.toggle-btn.on{background:var(--primary);color:#fff}.settings-btn{cursor:pointer;text-align:center;border:none;border-radius:12px;width:100%;margin-top:8px;padding:12px;font-size:.95rem;font-weight:600;display:block}.sync-btn{background:var(--primary);color:#fff}.logout-btn{background:var(--danger,#ef4444);color:#fff}.login-btn{background:var(--primary);color:#fff}.settings-user-info{color:var(--text-secondary);margin-bottom:8px;font-size:.85rem}.settings-about{text-align:center;color:var(--text-secondary);font-size:.85rem}.settings-about p{margin:4px 0}.pack-selector{scrollbar-width:none;gap:6px;padding:0 1rem .5rem;display:flex;overflow-x:auto}.pack-sel-btn{border:1.5px solid var(--border);background:var(--surface);color:var(--text-secondary);cursor:pointer;white-space:nowrap;border-radius:16px;flex-shrink:0;padding:6px 12px;font-size:.8rem}.pack-sel-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.browse-packs{padding:0 1rem 2rem}.browse-section-title{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;padding:.5rem 0 .3rem;font-size:.8rem;font-weight:600}.browse-pack-list{flex-direction:column;gap:.5rem;display:flex}.browse-pack-card{background:var(--surface);border:1px solid var(--border);cursor:pointer;border-radius:12px;justify-content:space-between;align-items:center;padding:.85rem 1rem;transition:all .15s;display:flex}.browse-pack-card:active{opacity:.8;transform:scale(.98)}.browse-pack-name{font-size:1rem;font-weight:600}.browse-pack-meta{color:var(--text-secondary);margin-top:2px;font-size:.8rem}.browse-pack-arrow{color:var(--text-muted);font-size:1.5rem}.browse-pack-detail{flex-direction:column;gap:.5rem;display:flex}.browse-detail-header{align-items:center;gap:.5rem;padding:.3rem 0;display:flex}.browse-detail-title{flex:1;font-size:1rem;font-weight:700}.browse-learn-btn{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:20px;padding:6px 14px;font-size:.85rem}.browse-search{border:1.5px solid var(--border);background:var(--surface);width:100%;color:var(--text);box-sizing:border-box;border-radius:10px;outline:none;padding:10px 14px;font-size:.95rem}.browse-search:focus{border-color:var(--primary)}.browse-word-list{flex-direction:column;gap:1px;max-height:60vh;display:flex;overflow-y:auto}.browse-word-row{border-bottom:1px solid var(--border);align-items:center;gap:.8rem;padding:.5rem;display:flex}.browse-word-lo{flex:1;font-size:1rem;font-weight:500}.browse-word-zh{color:var(--text-secondary);flex:1;font-size:.95rem}.browse-word-en{color:var(--text-muted);font-size:.8rem}.learn-tabs{scrollbar-width:none;gap:6px;padding:.75rem 1rem;display:flex;overflow-x:auto}.learn-tabs::-webkit-scrollbar{display:none}.learn-tab-btn{background:var(--surface);color:var(--text-secondary);cursor:pointer;box-shadow:var(--shadow);border:none;border-radius:20px;flex-shrink:0;padding:8px 16px;font-size:.85rem;font-weight:700;transition:all .2s}.learn-tab-btn.active{background:var(--primary);color:#fff;box-shadow:0 4px 12px var(--primary-glow)}.learn-content{padding:0 1rem}.fav-sort-bar{gap:8px;padding:.5rem 0;display:flex}.fav-sort-btn{border:1.5px solid var(--border);color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:16px;padding:5px 14px;font-size:.8rem;font-weight:600}.fav-sort-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.fav-group-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;padding:1rem 0 .25rem;font-size:.75rem;font-weight:700}.trans-history{margin-top:1rem}.trans-history-title{color:var(--text-secondary);margin-bottom:.5rem;font-size:.8rem;font-weight:700}.trans-history-item{border-bottom:1px solid var(--border-light);cursor:pointer;gap:8px;padding:8px 0;font-size:.85rem;display:flex}.trans-history-item:hover{background:var(--surface-hover)}.trans-history-from{color:var(--text);text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.trans-history-arrow{color:var(--text-muted);flex-shrink:0}.trans-history-to{color:var(--primary);text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}@keyframes pageSlideIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.page,.page.translate-page,.page.settings-page{animation:.2s ease-out pageSlideIn}.nav-item.active{color:var(--primary)}:root{--page-bg-layer-1:#f7f8ff;--page-bg-layer-2:#eef1ff;--page-bg-layer-3:#f5f2ff;--glass-border:#ffffff8c;--glass-highlight:#ffffffd1;--nav-grad-start:#ffffffeb;--nav-grad-end:#f4f6ffe0}[data-theme=dark]{--page-bg-layer-1:#0d1025;--page-bg-layer-2:#131935;--page-bg-layer-3:#15112d;--glass-border:#8492ff29;--glass-highlight:#ffffff14;--nav-grad-start:#14182cf0;--nav-grad-end:#1a1e3ae6}body{background:radial-gradient(circle at top center, #7e6cff24, transparent 36%), radial-gradient(circle at 100% 10%, #007aff1f, transparent 32%), linear-gradient(180deg, var(--page-bg-layer-1) 0%, var(--page-bg-layer-2) 45%, var(--page-bg-layer-3) 100%)}.hdr{background:linear-gradient(135deg,#745cfffa 0%,#488afff5 55%,#7e58d6fa 100%),linear-gradient(#ffffff29,#fff0);border:1px solid #ffffff1a;overflow:hidden;box-shadow:0 18px 40px #4e5fd63d,0 3px 10px #232b5d29,inset 0 1px #ffffff42}.hdr:before{content:"";pointer-events:none;background:linear-gradient(#ffffff38,#fff0);height:55%;position:absolute;inset:0 0 auto}.page{padding:.55rem var(--page-gutter) calc(90px + env(safe-area-inset-bottom,0px));min-height:calc(100vh - 110px)}.learn-page .learn-content,.translate-page .trans-wrap,.settings-page{position:relative}.bottom-nav{background:linear-gradient(180deg, var(--nav-grad-start), var(--nav-grad-end));border:1px solid #7c89ff1f;border-top-color:#ffffff73;border-radius:22px 22px 0 0;width:min(100%,520px);margin:0 auto;left:50%;right:auto;overflow:hidden;transform:translate(-50%);box-shadow:inset 0 -4px #ffffff61,0 -20px 40px #20295b1f,0 -6px 16px #7b5bff1a}.bottom-nav:before{content:"";pointer-events:none;background:linear-gradient(90deg,#0000,#ffffffe0,#0000);height:1px;position:absolute;top:0;left:10px;right:10px}.nav-item{padding:.6rem .35rem calc(.78rem + env(safe-area-inset-bottom,0px));letter-spacing:.01em;gap:.34rem;min-height:66px;font-size:11px;font-weight:700}.nav-item svg{width:21px;height:21px;transition:transform .22s,color .22s,filter .22s}.nav-item span{line-height:1}.nav-item.active svg{color:#4a63ff;filter:drop-shadow(0 6px 10px #4a63ff3d);transform:translateY(-1px)scale(1.05)}.nav-item.active:before{content:"";z-index:-1;background:linear-gradient(#657fff2e,#7a59ff1a);border:1px solid #7179ff29;border-radius:18px;position:absolute;inset:7px 10px 10px;box-shadow:inset 0 1px #ffffffb3,0 8px 20px #606dff1f}.nav-item.active:after{width:22px;height:3px;bottom:calc(8px + env(safe-area-inset-bottom,0px));background:linear-gradient(90deg,#6e7cff,#62b1ff);box-shadow:0 0 12px #62b1ff8c}[data-theme=dark] .bottom-nav{border-color:#ffffff14 #7a88ff2e #7a88ff2e;box-shadow:inset 0 -2px #ffffff0d,0 -24px 40px #00000059,0 -8px 18px #3043a233}[data-theme=dark] .nav-item.active:before{background:linear-gradient(#6976ff38,#5b49bf2e);border-color:#8391ff3d;box-shadow:inset 0 1px #ffffff14,0 10px 20px #27306259}.cats-scroll{padding:.8rem var(--page-gutter) .65rem;gap:.7rem}.cat-pill{min-height:44px;color:var(--text-secondary);background:linear-gradient(#fffffff5,#f6f8ffeb);border:1px solid #6e7cff24;border-radius:999px;padding:.68rem 1rem;font-size:.8rem;font-weight:700;box-shadow:0 8px 18px #717fff14,inset 0 1px #ffffffdb}.cat-pill.active{color:#fff;background:linear-gradient(135deg,#6a7cff 0%,#4b90ff 50%,#7a5dff 100%);border-color:#ffffff2e;box-shadow:0 10px 22px #5d73ff40,inset 0 1px #ffffff38}[data-theme=dark] .cat-pill{background:linear-gradient(#1c2241eb,#181c36f5);border-color:#7783ff33;box-shadow:0 10px 20px #0003,inset 0 1px #ffffff0d}.phrase-card{background:linear-gradient(#fffffffa,#f8fafff7),linear-gradient(135deg,#6c77ff0d,#50acff08);border:1px solid #6f7eff1f;border-radius:22px;padding:1.05rem 1rem 1rem;transition:transform .22s,box-shadow .22s,border-color .22s,background .22s;position:relative;overflow:hidden;box-shadow:0 14px 30px #535fb414,0 4px 12px #0f172a0a,inset 0 1px #ffffffe6}.phrase-card:before{content:"";pointer-events:none;background:linear-gradient(#7e89ff14,#fff0);height:54px;position:absolute;inset:0 0 auto}[data-theme=dark] .phrase-card{background:linear-gradient(#1b203efa,#181c36f5),linear-gradient(135deg,#7480ff1f,#4f86ff14);border-color:#7885ff2e;box-shadow:0 16px 30px #0000003d,inset 0 1px #ffffff0d}.phrase-card:hover,.phrase-card:focus-within{border-color:#657aff33;transform:translateY(-2px);box-shadow:0 18px 34px #5560be1f,0 6px 16px #0f172a14,inset 0 1px #ffffffe6}.phrase-card:active{background:linear-gradient(#f5f8fffa,#eff4fff5);transform:translateY(0)scale(.986);box-shadow:0 10px 20px #515fb61f}.card-lao-row{align-items:flex-start;gap:.7rem;margin-bottom:.85rem}.card-lao{letter-spacing:.01em;font-size:1.38rem;line-height:1.28}.card-roman{opacity:.88;margin-top:-.15rem;margin-bottom:.45rem;font-size:.88rem;line-height:1.5}.card-trans-item{align-items:flex-start;gap:.55rem}.trans-lang-label{margin-top:.15rem}.trans-text{font-size:.94rem;line-height:1.55}.card-category{background:linear-gradient(#ecf0fff2,#e5eaf9eb);border-radius:999px;padding:.32rem .72rem}.card-play-btn{background:linear-gradient(135deg,#617dff 0%,#3e97ff 100%);box-shadow:0 10px 18px #4577ff47,inset 0 1px #ffffff3d}.card-fav-btn{background:linear-gradient(#f3f5fcfa,#e8ecf7f0);box-shadow:inset 0 1px #fffc}.quick-translate-card{margin:.9rem var(--page-gutter) 1rem;background:linear-gradient(135deg,#647efffa 0%,#5895fff2 55%,#7857d6fa 100%);border:1px solid #ffffff29;border-radius:24px;padding:1.05rem;position:relative;overflow:hidden;box-shadow:0 20px 34px #5462ce38,inset 0 1px #ffffff3d}.quick-translate-card:before{content:"";pointer-events:none;background:linear-gradient(#ffffff29,#fff0);position:absolute;inset:0}.quick-translate-title{letter-spacing:.01em;margin-bottom:.9rem;font-size:.95rem;font-weight:800;position:relative}.quick-translate-input-row{align-items:stretch;gap:.65rem;position:relative}.quick-translate-input{color:#1f2955;background:#fffffff5;border:1px solid #ffffff40;border-radius:15px;outline:none;min-height:48px;font-size:.95rem;font-weight:500;transition:box-shadow .2s,transform .2s;box-shadow:inset 0 1px #fffffff2,0 8px 18px #202d7314}.quick-translate-input:focus{box-shadow:0 0 0 4px #fff3,0 10px 20px #202d7324}.quick-translate-btn{color:#5468ff;letter-spacing:.01em;background:linear-gradient(135deg,#fff 0%,#eef3ff 100%);border-radius:15px;min-width:84px;min-height:48px;font-weight:800;transition:transform .18s,box-shadow .18s,opacity .18s;box-shadow:0 10px 18px #232d6c24,inset 0 1px #fffffff2}.quick-translate-btn:hover{transform:translateY(-1px);box-shadow:0 14px 22px #232d6c2e,inset 0 1px #fffffff2}.quick-translate-btn:active{transform:scale(.97)}.quick-translate-result{-webkit-backdrop-filter:blur(10px);background:#ffffff24;border:1px solid #ffffff26;border-radius:16px;margin-top:.9rem;padding:.9rem .95rem;position:relative}.lo-text{font-size:1.14rem;font-weight:700;line-height:1.35}.copy-btn{background:#ffffff26;border-radius:12px;width:40px;height:40px}.learn-tab-btn{background:linear-gradient(#fffffffa,#f5f7fff2);border:1px solid #6c7aff1a;border-radius:999px;min-height:44px;padding:.72rem 1.05rem;box-shadow:0 8px 18px #505bb812,inset 0 1px #fffffff2}.quiz-start,.quiz-result,.flashcard-start,.flashcard-result,.quiz-container,.flashcard-container{background:linear-gradient(#ffffffd6,#f8faffdb);border:1px solid #6c7aff1a;border-radius:24px;box-shadow:0 18px 36px #4854b414,inset 0 1px #ffffffd1}[data-theme=dark] .quiz-start,[data-theme=dark] .quiz-result,[data-theme=dark] .flashcard-start,[data-theme=dark] .flashcard-result,[data-theme=dark] .quiz-container,[data-theme=dark] .flashcard-container{background:linear-gradient(#181d38eb,#14182ef0);border-color:#7684ff29;box-shadow:0 20px 36px #0000003d,inset 0 1px #ffffff0d}.quiz-start,.quiz-result,.flashcard-start,.flashcard-result{min-height:62vh;padding:1.5rem 1rem}.quiz-container,.flashcard-container{padding:1rem}.quiz-progress-bar{background:#6b7aff1f;border-radius:999px;height:8px}.quiz-progress-fill{background:linear-gradient(90deg, var(--accent), var(--accent-dark));box-shadow:0 4px 10px #5791ff3d}.start-btn,.restart-btn,.next-btn,.resume-btn,.play-main-btn,.know-btn,.unknown-btn,.feedback-submit{border-radius:16px;font-weight:800;box-shadow:0 12px 20px #5666df29}.start-btn,.restart-btn,.next-btn,.resume-btn,.play-main-btn,.know-btn{background:linear-gradient(135deg, var(--accent) 0%, var(--accent-dark) 100%)}.unknown-btn,.clear-wrong-btn{box-shadow:0 10px 18px #ef444429}.quiz-option,.result-item,.saved-progress,.correct-answer-hint,.result-tab,.quiz-count-selector select,.toggle-all-btn{border-radius:18px}.quiz-option{background:linear-gradient(#fffffffa,#f6f8fff5);border:1px solid #6f7eff1f;min-height:76px;padding:.95rem .75rem;box-shadow:0 10px 18px #525ebc0f,inset 0 1px #ffffffe0}.quiz-option:hover:not(:disabled),.quiz-option.selected{transform:translateY(-1px)}.result-item{background:linear-gradient(#fffffffa,#f7f9fff5);box-shadow:0 10px 20px #4a56b60f}.flashcard{max-width:100%;height:240px;position:relative}.flashcard-front,.flashcard-back{border:1px solid #6e7cff24;box-shadow:0 20px 40px #525fb829,inset 0 1px #ffffffbf}.flashcard-front{background:linear-gradient(#fffffffc,#f4f7fff7)}.flashcard-back{background:linear-gradient(135deg, var(--primary) 0%, var(--primary-dark) 100%)}.card-main{font-size:2rem;line-height:1.22}.card-lo{font-size:1.85rem;line-height:1.25}.card-en{opacity:.92}@media (width<=520px){.hdr{border-radius:0 0 22px 22px;margin-bottom:.25rem}.page{padding-top:.45rem}.bottom-nav{width:calc(100% - 10px);bottom:0}}@media (width<=420px){.nav-item{min-height:64px;padding-left:.2rem;padding-right:.2rem}.card-lao{font-size:1.24rem}.trans-text{font-size:.9rem}.quick-translate-input-row{flex-direction:column}.quick-translate-btn{width:100%}.quiz-options{grid-template-columns:1fr}.flashcard{height:224px}.result-stats{gap:1rem}}@media (width<=360px){.bottom-nav{border-radius:18px 18px 0 0;width:calc(100% - 6px)}.nav-item{gap:.28rem;font-size:10px}.nav-item svg{width:20px;height:20px}.phrase-card{border-radius:20px;padding:.95rem .85rem}.card-play-btn,.card-fav-btn,.play-btn,.fav-btn{width:44px;height:44px}.card-main{font-size:1.75rem}.card-lo{font-size:1.6rem}}.page.translate-page{padding-left:.45rem;padding-right:.45rem;padding-bottom:calc(76px + env(safe-area-inset-bottom,0px))}.trans-wrap,.settings-wrap{-webkit-backdrop-filter:blur(20px);background:#ffffffdb}[data-theme=dark] .trans-wrap,[data-theme=dark] .settings-wrap{background:#181c2ed6}.translate-page .trans-wrap{border-radius:24px;width:100%;margin:.35rem 0 .5rem;padding:.95rem;box-shadow:0 18px 34px #505ebe1f,0 4px 12px #0f172a0d,inset 0 1px #ffffffb3}.translate-page .trans-header{margin-bottom:.9rem}.trans-title{letter-spacing:.1em;font-size:.9rem}.trans-history-toggle,.trans-arrow-btn{color:var(--primary);background:linear-gradient(#fffffff2,#f1f5ffeb);border:1px solid #667eea24;box-shadow:0 8px 18px #606dff1a,inset 0 1px #ffffffe6}.trans-history-toggle{cursor:pointer;border-radius:14px;width:42px;height:42px;font-size:1rem}.trans-row{gap:.7rem;margin-bottom:.8rem}.trans-lang-select{background:linear-gradient(#fffffff5,#f4f7ffeb);background-image:linear-gradient(45deg, transparent 50%, var(--primary) 50%), linear-gradient(135deg, var(--primary) 50%, transparent 50%), linear-gradient(180deg, #fffffff5, #f4f7ffeb);background-position:calc(100% - 18px) calc(50% - 3px),calc(100% - 12px) calc(50% - 3px),0 0;background-repeat:no-repeat;background-size:6px 6px,6px 6px,100% 100%;border:1.5px solid #667eea29;border-radius:14px;min-height:48px;padding:.75rem 2.3rem .75rem .9rem;font-size:1rem;font-weight:700;line-height:1.2;box-shadow:inset 0 1px #fffffff2}.trans-lang-select:focus,.trans-input:focus{border-color:#4a63ffb3;box-shadow:0 0 0 4px #4a63ff1f}.trans-arrow-btn{cursor:pointer;border-radius:14px;width:48px;min-width:48px;height:48px;font-size:1.2rem}.trans-input{background:linear-gradient(#fffffffa,#f7f9fff0);border:1.5px solid #667eea29;border-radius:18px;min-height:124px;margin-bottom:.8rem;padding:.95rem 1rem;font-weight:500;line-height:1.75;box-shadow:inset 0 1px #fffffff2;font-size:1.1rem!important}.trans-input::placeholder{font-size:1rem}.trans-submit-btn{letter-spacing:.01em;background:linear-gradient(135deg,#5d7cff 0%,#3f96ff 55%,#7660ff 100%);border-radius:18px;min-height:54px;padding:.95rem 1.2rem;font-size:1.08rem;font-weight:800;box-shadow:0 16px 28px #4a6eff47,inset 0 1px #ffffff47}.trans-submit-btn:active{background:linear-gradient(135deg,#4768f6 0%,#2f84eb 55%,#654df4 100%)}.trans-result-box{background:linear-gradient(#fffffff0,#f4f7ffe6);border:1px solid #667eea1f;border-radius:20px;margin-top:.9rem;padding:1rem 1.05rem;box-shadow:0 12px 24px #4a56b614}.trans-result,.trans-result-lo{font-size:1.35rem;line-height:1.65}.trans-result-actions{flex-wrap:wrap;gap:.65rem}.trans-play-btn,.trans-action-btn{border-radius:14px;min-height:46px;padding:0 1rem;font-size:.92rem;font-weight:700}.trans-history{margin-top:1rem;padding-top:.9rem}.trans-history-title{margin-bottom:.7rem;font-size:.82rem}.trans-history-item{border:1px solid #667eea14;border-radius:14px;margin-bottom:.45rem;padding:.75rem .8rem;font-size:.98rem}.trans-history-arrow{font-size:.9rem}.mic-btn{border-radius:16px;justify-content:center;align-items:center;width:52px;height:52px;font-size:1.15rem;display:inline-flex;box-shadow:0 12px 24px #4a63ff2e}@media (width<=480px){.page.translate-page{padding-left:.35rem;padding-right:.35rem;padding-bottom:calc(74px + env(safe-area-inset-bottom,0px))}.translate-page .trans-wrap{border-radius:20px;margin-top:.2rem;padding:.85rem}.trans-lang-select,.trans-arrow-btn,.trans-history-toggle,.trans-submit-btn{min-height:46px}.trans-input{min-height:112px;padding:.88rem .9rem}.trans-result,.trans-result-lo{font-size:1.22rem}}:root{--hero-grad:linear-gradient(135deg, #6b7dff 0%, #3d9bff 42%, #8b5cff 100%);--hero-grad-soft:linear-gradient(180deg, #6b7dff24, #3d9bff14 45%, #8b5cff0f 100%);--surface-strong:#ffffffeb;--surface-soft:#f8faffe6;--line-strong:#6b7dff29}[data-theme=dark]{--surface-strong:#14182ee6;--surface-soft:#1a1f3ae0;--line-strong:#919cff2e}.page.translate-page{padding-top:.35rem;padding-left:0;padding-right:0;padding-bottom:calc(92px + env(safe-area-inset-bottom,0px))}.translate-page .trans-wrap{width:100%;box-shadow:none;-webkit-backdrop-filter:none;background:0 0;border:none;border-radius:0;margin:0;padding:.75rem .9rem .9rem}.translate-page .trans-wrap:before{content:"";height:0;display:block}.translate-page .trans-header{margin-bottom:.9rem;padding:0 .1rem}.translate-page .trans-title{letter-spacing:.02em;color:var(--text);text-transform:none;font-size:1.15rem;font-weight:900}.trans-history-toggle{border:1px solid var(--line-strong);background:var(--surface-strong);width:48px;height:48px;color:var(--primary);border-radius:16px;font-size:1.08rem;font-weight:700;box-shadow:0 14px 28px #4d60c41f}.translate-page .trans-row:first-of-type{grid-template-columns:repeat(2,minmax(0,1fr));display:grid;gap:.7rem!important;margin-bottom:.9rem!important}.translate-page .trans-row:first-of-type button{letter-spacing:.01em;min-height:52px;box-shadow:0 12px 24px #4e59ae14,inset 0 1px #ffffffc7;background:var(--surface-strong)!important;color:var(--text)!important;border:1px solid #ffffff2e!important;border-radius:18px!important;padding:.9rem .7rem!important;font-size:1.02rem!important;font-weight:800!important}.translate-page .trans-row:first-of-type button[style*="255, 255, 255"],.translate-page .trans-row:first-of-type button[style*=\#fff]{color:#fff!important}.translate-page .trans-row:first-of-type button[style*=var\(--primary],.translate-page .trans-row:first-of-type button[style*="rgb(0, 122, 255)"],.translate-page .trans-row:first-of-type button[style*=\#007AFF]{background:var(--hero-grad)!important;color:#fff!important;box-shadow:0 18px 32px #456cff3d!important}.translate-page .trans-row:nth-of-type(2){align-items:stretch;gap:.7rem;margin-bottom:.95rem}.trans-lang-select{border:1px solid var(--line-strong);background-color:var(--surface-strong);min-height:56px;color:var(--text);border-radius:18px;padding:.9rem 2.5rem .9rem 1rem;font-size:1.05rem;font-weight:800;box-shadow:0 10px 24px #3d4fae14}.trans-arrow-btn{background:var(--hero-grad);color:#fff;border:none;border-radius:18px;width:56px;min-width:56px;height:56px;font-size:1.35rem;font-weight:900;box-shadow:0 18px 30px #466dff3d}.trans-input{background:linear-gradient(180deg, #fffffff5, #f7f9ffeb), var(--hero-grad-soft);min-height:180px;color:var(--text);border:1px solid #6e7eff24;border-radius:24px;padding:1.2rem 1.1rem;font-weight:600;line-height:1.75;box-shadow:0 20px 40px #4e5cb61f,inset 0 1px #ffffffeb;font-size:1.14rem!important}.trans-input::placeholder{color:var(--text-secondary);opacity:.7;font-size:1rem}.trans-submit-btn{background:var(--hero-grad);letter-spacing:.02em;border-radius:20px;min-height:58px;font-size:1.12rem;font-weight:900;box-shadow:0 22px 34px #4168ff47,inset 0 1px #ffffff42}.trans-result-box{box-shadow:none;background:0 0;border:none;border-radius:0;margin-top:1rem;padding:.4rem 0 0}.trans-result-lo{color:var(--text);word-break:break-word;margin-bottom:.9rem;font-size:1.6rem;font-weight:900;line-height:1.72}.trans-result-actions{grid-template-columns:repeat(2,minmax(0,1fr));gap:.8rem;display:grid}.trans-play-btn,.trans-action-btn{border:none;border-radius:18px;min-height:56px;padding:0 1rem;font-size:1rem;font-weight:800}.trans-play-btn{background:var(--hero-grad);color:#fff;box-shadow:0 18px 30px #476cff38}.trans-action-btn{background:var(--surface-strong);color:var(--text);border:1px solid var(--line-strong);box-shadow:0 12px 24px #4e59ae14}.trans-history{background:0 0;border-top:none;margin-top:.9rem;padding-top:0}.trans-history-title{color:var(--primary);background:#6b7dff1a;border-radius:999px;align-items:center;gap:.4rem;margin-bottom:.75rem;padding:.4rem .8rem;font-size:.82rem;font-weight:800;display:inline-flex}.trans-history-item{border:1px solid var(--line-strong);background:var(--surface-soft);border-radius:18px;align-items:center;gap:.55rem;margin-bottom:.55rem;padding:.9rem .95rem;box-shadow:0 12px 24px #404daa0f}.trans-history-from,.trans-history-to{font-size:.96rem;line-height:1.45}.trans-history-from{color:var(--text-secondary)}.trans-history-to{color:var(--text);font-weight:800}.bottom-nav{-webkit-backdrop-filter:blur(22px)saturate(160%);background:linear-gradient(#fffffff0,#f4f7ffeb),linear-gradient(135deg,#6a7cff14,#419aff0a);border:1px solid #ffffff59;border-radius:24px;width:calc(100% - 12px);bottom:6px;box-shadow:0 24px 44px #252f602e,0 8px 18px #6271ff1a,inset 0 1px #ffffffbf}.bottom-nav:after{content:"";pointer-events:none;background:linear-gradient(#0000,#7886ff29,#0000);width:1px;position:absolute;top:10px;bottom:10px;left:25%;box-shadow:25vw 0 #7886ff29,50vw 0 #7886ff29}.nav-item{min-height:70px;padding:.7rem .2rem calc(.9rem + env(safe-area-inset-bottom,0px));color:#4a527ab8;font-size:.72rem;font-weight:800}.nav-item svg{width:23px;height:23px}.nav-item.active{color:#476cff;transform:translateY(-3px)}.nav-item.active svg{transform:scale(1.16)}.nav-item.active:before{background:linear-gradient(#5f76ff33,#7b59ff24);border-radius:18px;inset:7px 10px 12px}.nav-item.active:after{border-radius:999px;width:28px;height:4px}.cats-scroll{gap:.75rem;padding-top:.95rem;padding-bottom:.85rem}.cat-pill{border:1px solid var(--line-strong);background:var(--surface-strong);min-height:46px;color:var(--text-secondary);border-radius:999px;padding:.76rem 1.05rem;font-size:.88rem;font-weight:800;box-shadow:0 10px 22px #5462ba14}.cat-pill.active{background:var(--hero-grad);color:#fff;box-shadow:0 16px 28px #526eff3d}.phrase-list{gap:1.05rem;padding-top:.25rem}.phrase-card{border:1px solid var(--line-strong);background:linear-gradient(#fffffffa,#f6f8fff5),linear-gradient(135deg,#677cff0f,#4799ff08);border-radius:24px;padding:1.15rem 1.05rem 1rem;box-shadow:0 18px 34px #4d5cb21a,inset 0 1px #ffffffd6}.card-lao-row{gap:.8rem;margin-bottom:.95rem}.card-lao{color:var(--text);font-size:1.42rem;font-weight:900}.card-roman{margin-bottom:.55rem;font-size:.92rem;line-height:1.55}.card-trans{gap:.55rem;margin-bottom:.75rem}.trans-lang-label{border-radius:999px;padding:.28rem .5rem;font-size:.68rem}.trans-text{color:var(--text);font-size:1rem;line-height:1.62}.card-actions{gap:.6rem}.card-play-btn,.card-fav-btn,.play-btn,.fav-btn{border-radius:18px;width:52px;height:52px}.card-play-btn,.play-btn{background:var(--hero-grad);color:#fff;box-shadow:0 16px 28px #496bff3d}.card-fav-btn,.fav-btn{background:var(--surface-strong);color:var(--text-secondary);border:1px solid var(--line-strong);box-shadow:0 10px 22px #5462ba14}.card-fav-btn.active,.fav-btn.active{color:#fff;background:linear-gradient(135deg,#ff6a93 0%,#ff4d7a 100%);border-color:#0000}.card-category{border-radius:999px;margin-top:.35rem;padding:.38rem .8rem;font-size:.76rem;font-weight:700}.learn-page .learn-content,.quiz-start,.quiz-result,.flashcard-start,.flashcard-result,.quiz-container,.flashcard-container{border:1px solid var(--line-strong);background:linear-gradient(#fffffff2,#f7f9ffeb);border-radius:26px;box-shadow:0 20px 38px #4b5ab21a}.learn-page .learn-content{padding:.15rem .75rem .9rem}.learn-tabs{gap:.75rem;padding:.8rem 0 1rem}.learn-tab-btn{background:var(--surface-strong);border:1px solid var(--line-strong);border-radius:999px;min-height:46px;padding:.8rem 1.15rem;font-size:.9rem;font-weight:800;box-shadow:0 10px 22px #5462ba14}.learn-tab-btn.active{background:var(--hero-grad);box-shadow:0 16px 28px #526eff3d}.quiz-question h3,.card-main,.card-lo{font-weight:900}.quiz-question h3{font-size:2rem;line-height:1.3}.quiz-option{border:1px solid var(--line-strong);background:var(--surface-strong);border-radius:20px;min-height:82px}.opt-lo{font-size:1.12rem;font-weight:800}.opt-zh{font-size:1rem}.flashcard{height:252px}.flashcard-front,.flashcard-back{border-radius:26px}.card-main{font-size:2.1rem}.card-lo{font-size:1.92rem}.card-en{font-size:1rem}.start-btn,.restart-btn,.next-btn,.resume-btn,.play-main-btn,.know-btn,.unknown-btn,.clear-wrong-btn,.toggle-all-btn,.result-tab{border-radius:18px;min-height:52px;font-weight:800}[data-theme=dark] .translate-page .trans-wrap,[data-theme=dark] .trans-input,[data-theme=dark] .trans-history-item,[data-theme=dark] .trans-action-btn,[data-theme=dark] .trans-lang-select,[data-theme=dark] .cat-pill,[data-theme=dark] .phrase-card,[data-theme=dark] .learn-tab-btn,[data-theme=dark] .quiz-option,[data-theme=dark] .learn-page .learn-content,[data-theme=dark] .quiz-start,[data-theme=dark] .quiz-result,[data-theme=dark] .flashcard-start,[data-theme=dark] .flashcard-result,[data-theme=dark] .quiz-container,[data-theme=dark] .flashcard-container,[data-theme=dark] .card-fav-btn,[data-theme=dark] .fav-btn,[data-theme=dark] .trans-history-toggle{color:var(--text);background:linear-gradient(#181d38f5,#12172cf0);border-color:#8895ff29;box-shadow:0 18px 32px #0000003d,inset 0 1px #ffffff0a}[data-theme=dark] .trans-result-box{box-shadow:none;background:0 0}[data-theme=dark] .trans-result-lo,[data-theme=dark] .card-lao,[data-theme=dark] .trans-history-to{color:#eef2ff}[data-theme=dark] .flashcard-back{background:linear-gradient(135deg, var(--accent) 0%, var(--primary-dark) 100%);color:#f3f4f6}[data-theme=dark] .flashcard-front{background:linear-gradient(#1e233cfa,#181d38f2)}[data-theme=dark] .quiz-option.correct{border-color:var(--success);background:#34c75938}[data-theme=dark] .quiz-option.wrong{border-color:var(--danger);background:#ef444438}[data-theme=dark] .quiz-option.selected{border-color:var(--primary-dark);background:#818cf82e}[data-theme=dark] .bottom-nav{background:linear-gradient(#12172cf5,#181d38f0);border-color:#7d8dff24;box-shadow:0 26px 44px #00000061,inset 0 1px #ffffff0a}[data-theme=dark] .nav-item{color:#dde4ff9e}[data-theme=dark] .nav-item.active{color:#b8c4ff}@media (width<=480px){.translate-page .trans-wrap{padding:.7rem .75rem .8rem}.trans-input{min-height:160px;font-size:1.08rem!important}.trans-result-lo{font-size:1.46rem}.trans-play-btn,.trans-action-btn,.trans-submit-btn,.trans-lang-select,.trans-arrow-btn,.trans-history-toggle{min-height:52px}.phrase-card{padding:1rem .95rem .95rem}}@media (width<=380px){.translate-page .trans-row:first-of-type{grid-template-columns:1fr}.translate-page .trans-row:nth-of-type(2){gap:.55rem}.trans-result-actions{grid-template-columns:1fr}.card-lao{font-size:1.32rem}.trans-text,.trans-history-from,.trans-history-to{font-size:.94rem}}@media (width>=768px){:root{--page-gutter:1.5rem}.app{max-width:min(1120px,100vw - 48px);padding-bottom:2rem}.main-content{-webkit-user-select:none;user-select:none;cursor:grab}.main-content:active{cursor:grabbing}.page,.settings-page,.learn-page .learn-content,.translate-page .trans-wrap,.quiz-start,.quiz-result,.flashcard-start,.flashcard-result,.quiz-container,.flashcard-container{max-width:min(1040px,100vw - 96px);margin-left:auto;margin-right:auto}.page{min-height:calc(100vh - 96px);padding-bottom:2rem}.phrase-list{gap:1.1rem}.phrase-card,.quiz-option,.result-item,.settings-section,.learn-tab-btn,.cat-pill,.tab-btn,.trans-history-item,.trans-play-btn,.trans-action-btn,.settings-lang-btn,.toggle-btn,.login-btn,.quick-translate-btn,.apple-export-btn,.export-fav-btn{transition:transform .22s,box-shadow .22s,border-color .22s,background .22s,color .22s}.phrase-card:hover,.quiz-option:hover:not(:disabled),.result-item:hover,.settings-section:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}.card-play-btn:hover,.card-fav-btn:hover,.play-btn:hover,.fav-btn:hover,.hdr-icon-btn:hover,.locale-btn:hover,.tab-btn:hover,.cat-pill:hover,.learn-tab-btn:hover,.settings-lang-btn:hover,.toggle-btn:hover,.login-btn:hover,.quick-translate-btn:hover,.apple-export-btn:hover,.export-fav-btn:hover,.trans-submit-btn:hover,.trans-play-btn:hover,.trans-action-btn:hover{transform:translateY(-2px);box-shadow:0 14px 28px #4a63ff2e}.toast{bottom:24px}}.share-stats-card{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-radius:22px;padding:1.25rem;box-shadow:0 16px 32px #667eea47}.share-stats-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.share-stats-date{opacity:.9;font-size:.85rem;font-weight:700}.share-streak{background:#fff3;border-radius:999px;padding:.25rem .7rem;font-size:.78rem;font-weight:700}.share-stats-grid{grid-template-columns:repeat(3,1fr);gap:.75rem;display:grid}.share-stat-item{text-align:center;background:#ffffff26;border-radius:14px;padding:.85rem .5rem}.share-stat-num{font-size:1.75rem;font-weight:900;line-height:1.1}.share-stat-label{opacity:.85;margin-top:2px;font-size:.72rem}.share-proverb-card{background:var(--surface);text-align:center;box-shadow:var(--shadow-md);border:1px solid var(--border);border-radius:22px;padding:1.25rem}.share-proverb-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.75rem;font-size:.75rem;font-weight:700}.share-proverb-lo{color:var(--primary);cursor:pointer;margin-bottom:.5rem;font-size:1.5rem;font-weight:900;line-height:1.4;transition:opacity .2s}.share-proverb-lo:hover{opacity:.75}.share-proverb-zh{color:var(--text);margin-bottom:.25rem;font-size:1rem;font-weight:600}.share-proverb-en{color:var(--text-secondary);font-size:.82rem}.share-actions{gap:.75rem;display:flex}.share-btn{border:1.5px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;border-radius:16px;flex:1;padding:.85rem;font-family:inherit;font-size:.95rem;font-weight:700;transition:all .2s}.share-btn.primary{background:var(--hero-grad,linear-gradient(135deg, #667eea 0%, #764ba2 100%));color:#fff;border-color:#0000;box-shadow:0 12px 24px #667eea3d}.share-btn:active{transform:scale(.96)}.share-proverbs-list{background:var(--surface);box-shadow:var(--shadow);border:1px solid var(--border);border-radius:22px;padding:1rem}.share-proverbs-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.85rem;font-size:.78rem;font-weight:700}.share-proverb-item{border-bottom:1px solid var(--border-light);cursor:pointer;border-radius:8px;gap:.75rem;padding:.6rem .5rem;transition:background .15s;display:flex}.share-proverb-item:last-child{border-bottom:none}.share-proverb-item:hover{background:var(--surface-hover)}.share-proverb-item-lo{color:var(--primary);flex-shrink:0;min-width:100px;font-size:.9rem;font-weight:700}.share-proverb-item-zh{color:var(--text-secondary);font-size:.88rem}.announcement-banner{margin:.75rem 0}.announcement-item{color:var(--primary);background:linear-gradient(135deg,#667eea1f,#764ba21f);border:1px solid #667eea33;border-radius:12px;margin-bottom:.5rem;padding:.75rem 1rem;font-size:.88rem}.login-modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:9999;background:#000000b3;justify-content:center;align-items:center;padding:16px;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.login-modal{background:var(--card-bg,#1e1e2e);border:1px solid #ffffff1a;border-radius:24px;width:100%;max-width:400px;padding:40px 32px 32px;animation:.25s slideUp;position:relative;box-shadow:0 24px 80px #00000080}.login-modal-close{color:var(--text-secondary,#888);cursor:pointer;background:0 0;border:none;padding:4px;font-size:24px;line-height:1;position:absolute;top:12px;right:16px}.login-modal-logo{text-align:center;margin-bottom:16px}.login-modal-logo img{border-radius:16px;width:64px;height:64px;box-shadow:0 4px 20px #4a90d966}.login-modal-title{text-align:center;color:var(--text,#fff);margin:0 0 8px;font-size:24px;font-weight:700}.login-modal-sub{text-align:center;color:var(--text-secondary,#aaa);margin:0 0 24px;font-size:14px}.login-error{color:#e94560;background:#e9456026;border:1px solid #e945604d;border-radius:10px;margin-bottom:16px;padding:10px 14px;font-size:13px}.login-input{box-sizing:border-box;width:100%;color:var(--text,#fff);background:#ffffff0d;border:1.5px solid #ffffff1a;border-radius:12px;outline:none;margin-bottom:12px;padding:14px 16px;font-size:15px;transition:border-color .2s}.login-input:focus{border-color:var(--primary,#4a90d9)}.login-submit-btn{background:var(--primary,#4a90d9);color:#fff;cursor:pointer;border:none;border-radius:12px;width:100%;margin-top:4px;padding:14px;font-size:16px;font-weight:600;transition:opacity .2s,transform .1s}.login-submit-btn:active{opacity:.9;transform:scale(.98)}.login-divider{color:var(--text-secondary,#888);align-items:center;gap:12px;margin:20px 0;font-size:13px;display:flex}.login-divider:before,.login-divider:after{content:"";background:#ffffff1a;flex:1;height:1px}.login-google-btn{width:100%;color:var(--text,#fff);cursor:pointer;background:#ffffff14;border:1.5px solid #ffffff1f;border-radius:12px;justify-content:center;align-items:center;gap:10px;padding:13px;font-size:15px;transition:background .2s;display:flex}.login-google-btn:hover{background:#ffffff21}.login-toggle-mode{text-align:center;color:var(--text-secondary,#aaa);margin:20px 0 0;font-size:13px}.login-toggle-mode span{color:var(--primary,#4a90d9);cursor:pointer;margin-left:6px;font-weight:600}@keyframes slideUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.share-page{padding:.75rem 1rem calc(100px + env(safe-area-inset-bottom,0px));flex-direction:column;gap:.85rem;display:flex}.share-hero-card{color:#fff;cursor:pointer;text-align:center;background:linear-gradient(135deg,#667eea 0%,#764ba2 30%,#f093fb 70%,#f5576c 100%);border-radius:28px;padding:2rem 1.75rem;transition:transform .25s,box-shadow .25s;position:relative;overflow:hidden;box-shadow:0 20px 50px #667eea73,inset 0 0 0 1px #ffffff1a}.share-hero-card:before{content:"";pointer-events:none;background:linear-gradient(#ffffff26 0%,#0000 60%);position:absolute;inset:0}.share-hero-card:active{transform:scale(.98);box-shadow:0 10px 24px #667eea59}.share-hero-date{text-transform:uppercase;letter-spacing:.08em;opacity:.85;margin-bottom:.85rem;font-size:.75rem;font-weight:700}.share-hero-lo{letter-spacing:.01em;margin-bottom:.75rem;font-size:1.85rem;font-weight:900;line-height:1.35}.share-hero-zh{opacity:.92;margin-bottom:.6rem;font-size:1.05rem;font-weight:600}.share-hero-hint{opacity:.55;letter-spacing:.04em;font-size:.72rem}.share-day-tabs{scrollbar-width:none;gap:.5rem;padding-bottom:2px;display:flex;overflow-x:auto}.share-day-tabs::-webkit-scrollbar{display:none}.share-day-tab{color:#fff9;cursor:pointer;box-shadow:none;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff0f;border:1.5px solid #ffffff1a;border-radius:16px;flex-direction:column;flex-shrink:0;align-items:center;gap:3px;min-width:60px;padding:.7rem 1rem;transition:all .25s;display:flex}.share-day-tab.active{color:#fff;background:linear-gradient(135deg,#667eea80,#764ba280);border-color:#667eea99;transform:translateY(-2px);box-shadow:0 4px 16px #667eea59}.day-label{letter-spacing:.04em;font-size:.72rem;font-weight:800}.day-date{opacity:.65;font-size:.65rem}.share-stats-row{grid-template-columns:repeat(4,1fr);gap:.6rem;display:grid}.share-stat-chip{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);text-align:center;background:#ffffff1a;border:1px solid #ffffff26;border-radius:18px;flex-direction:column;gap:4px;padding:1rem .5rem;transition:transform .2s;display:flex;box-shadow:0 6px 20px #0000002e}.share-stat-chip:hover{transform:translateY(-2px)}.chip-num{background:linear-gradient(135deg,#667eea,#f093fb);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.3rem;font-weight:900;line-height:1}.chip-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:.65rem;font-weight:600}.share-actions{justify-content:center;padding:.5rem 0;display:flex}.share-card-btn{color:#fff;cursor:pointer;letter-spacing:.03em;background:linear-gradient(135deg,#667eea 0%,#764ba2 50%,#f093fb 100%);border:none;border-radius:50px;width:100%;max-width:340px;margin:0 auto;padding:1rem 2rem;font-family:inherit;font-size:1.1rem;font-weight:800;transition:all .25s;position:relative;overflow:hidden;box-shadow:0 8px 32px #667eea80}.share-card-btn:before{content:"";pointer-events:none;background:linear-gradient(#ffffff40 0%,#0000 50%);position:absolute;inset:0}.share-card-btn:hover{transform:translateY(-2px);box-shadow:0 12px 40px #667eea99}.share-card-btn:active{transform:translateY(0)scale(.97);box-shadow:0 6px 24px #667eea66}.share-card-btn:disabled{opacity:.55;cursor:not-allowed;transform:none}.share-preview-overlay{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:9000;background:#000000d1;justify-content:center;align-items:center;padding:16px;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.share-preview-modal{background:#1a1a2e;border-radius:24px;width:100%;max-width:420px;animation:.25s slideUp;overflow:hidden;box-shadow:0 24px 60px #00000080}.share-preview-header{color:#fff;border-bottom:1px solid #ffffff14;justify-content:space-between;align-items:center;padding:16px 20px;font-size:15px;font-weight:600;display:flex}.preview-close-btn{color:#fff;cursor:pointer;background:#ffffff1a;border:none;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:14px;display:flex}.preview-close-btn:hover{background:#fff3}.share-preview-image-wrap{justify-content:center;align-items:center;min-height:200px;padding:16px;display:flex}.share-preview-image{opacity:0;border-radius:12px;width:100%;transition:opacity .3s;box-shadow:0 8px 24px #0006}.share-preview-image.loaded{opacity:1}.share-mobile-hint{text-align:center;color:#ffffff80;padding:0 16px 8px;font-size:13px}.share-preview-loading{color:#ffffff80;flex-direction:column;align-items:center;gap:12px;font-size:14px;display:flex}.spinner{border:3px solid #ffffff26;border-top-color:#4a90d9;border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}.share-channel-grid{grid-template-columns:repeat(3,1fr);gap:10px;padding:0 16px 20px;display:grid}.share-channel-btn{cursor:pointer;color:#fff;background:#ffffff12;border:1px solid #ffffff1a;border-radius:16px;flex-direction:column;align-items:center;gap:6px;padding:14px 8px;transition:background .2s,transform .15s;display:flex}.share-channel-btn:hover{background:#ffffff24;transform:scale(1.04)}.share-channel-btn:active{transform:scale(.96)}.share-channel-btn.wechat{border-color:#4cbf4066}.share-channel-btn.wechat:hover{background:#4cbf4026}.share-channel-btn.qq{border-color:#00b7ff59}.share-channel-btn.qq:hover{background:#00b7ff26}.share-channel-btn.weibo{border-color:#e0502066}.share-channel-btn.weibo:hover{background:#e0502026}.share-channel-btn.native{border-color:#007aff66}.share-channel-btn.native:hover{background:#007aff26}.share-channel-btn.save{border-color:#ffc10766}.share-channel-btn.save:hover{background:#ffc10726}.share-channel-btn.copy{border-color:#7c4dff66}.share-channel-btn.copy:hover{background:#7c4dff26}.channel-name{opacity:.8;font-size:12px}.learn-guide-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:9000;background:#000000bf;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.learn-guide-card{background:var(--card-bg,#1e1e2e);text-align:center;border:1px solid #ffffff1a;border-radius:24px;width:100%;max-width:380px;padding:32px 28px 24px;animation:.25s slideUp;box-shadow:0 24px 80px #00000080}.learn-guide-icon{margin-bottom:12px;font-size:3.5rem;display:block}.learn-guide-title{color:var(--text);margin-bottom:10px;font-size:1.35rem;font-weight:800;display:block}.learn-guide-desc{color:var(--text-secondary);margin:0 0 20px;font-size:.95rem;line-height:1.55}.learn-guide-dots{justify-content:center;gap:8px;margin-bottom:20px;display:flex}.guide-dot{background:#fff3;border-radius:50%;width:8px;height:8px;transition:all .2s}.guide-dot.active{background:var(--primary);border-radius:4px;width:24px}.learn-guide-actions{justify-content:space-between;gap:12px;margin-bottom:12px;display:flex}.guide-btn{cursor:pointer;border:none;border-radius:12px;flex:1;padding:12px;font-family:inherit;font-size:.95rem;font-weight:700;transition:opacity .2s}.guide-btn:active{opacity:.85}.guide-btn.primary{background:var(--primary);color:#fff}.guide-btn.secondary{color:var(--text-secondary);background:#ffffff14;border:1px solid #ffffff1a}.guide-skip{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:4px 8px;font-size:.82rem}.fav-sort-row{justify-content:space-between;align-items:center;padding:.5rem .25rem .75rem;display:flex}.fav-count{color:var(--text-secondary);font-size:.82rem;font-weight:700}.fav-sort-select{border:1.5px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;border-radius:10px;outline:none;padding:6px 10px;font-family:inherit;font-size:.8rem;font-weight:600}.daily-goal-card{background:var(--surface);border:1px solid var(--border);border-radius:18px;padding:1rem 1.1rem;box-shadow:0 2px 12px #0000000f}.daily-goal-header{justify-content:space-between;align-items:center;margin-bottom:.6rem;display:flex}.daily-goal-title{color:var(--text);letter-spacing:.02em;font-size:.82rem;font-weight:800}.daily-goal-count{color:var(--primary);font-size:.75rem;font-weight:700}.daily-goal-bar-bg{background:var(--border);border-radius:4px;height:8px;margin-bottom:.45rem;overflow:hidden}.daily-goal-bar-fill{background:linear-gradient(90deg,#4a90d9,#7ed321);border-radius:4px;height:100%;transition:width .6s}.daily-goal-done{color:#7ed321;text-align:center;font-size:.78rem;font-weight:700}.daily-goal-hint{color:var(--text-muted);text-align:center;font-size:.72rem}.ach-toast{z-index:9998;background:linear-gradient(135deg,#1a1a2e,#16213e);border:1.5px solid #ffd70066;border-radius:16px;align-items:center;gap:12px;max-width:280px;padding:12px 16px;animation:.4s cubic-bezier(.34,1.56,.64,1) achSlideIn;display:flex;position:fixed;top:60px;right:16px;box-shadow:0 8px 32px #ffd70033,0 4px 16px #0006}@keyframes achSlideIn{0%{opacity:0;transform:translate(60px)scale(.8)}to{opacity:1;transform:translate(0)scale(1)}}.ach-toast-icon{flex-shrink:0;font-size:2.2rem}.ach-toast-title{color:gold;text-transform:uppercase;letter-spacing:.08em;margin-bottom:2px;font-size:.7rem;font-weight:800}.ach-toast-name{color:#fff;margin-bottom:2px;font-size:.88rem;font-weight:800}.ach-toast-desc{color:#fff9;font-size:.72rem}.ach-badges-row{overflow:hidden}.ach-badges-scroll{scrollbar-width:none;gap:.5rem;padding-bottom:2px;display:flex;overflow-x:auto}.ach-badges-scroll::-webkit-scrollbar{display:none}.ach-badge{border:1.5px solid var(--border);background:var(--surface);border-radius:20px;flex-shrink:0;align-items:center;gap:4px;padding:5px 10px;transition:all .2s;display:flex}.ach-badge.locked{opacity:.35;filter:grayscale()}.ach-badge.unlocked{background:#ffd70014;border-color:#ffd7004d}.ach-badge-icon{font-size:1.1rem}.ach-badge-name{color:var(--text);white-space:nowrap;font-size:.72rem;font-weight:700}.ach-grid{grid-template-columns:repeat(3,1fr);gap:.6rem;margin-bottom:.75rem;display:grid}.ach-card{background:var(--surface);border:1px solid var(--border);text-align:center;border-radius:12px;padding:.75rem .5rem;transition:all .2s}.ach-card.locked{opacity:.4;filter:grayscale()}.ach-card.unlocked{background:#ffd7000d;border-color:#ffd70040}.ach-card-icon{margin-bottom:4px;font-size:1.6rem}.ach-card-name{color:var(--text);margin-bottom:2px;font-size:.68rem;font-weight:800}.ach-card-desc{color:var(--text-muted);font-size:.6rem;line-height:1.3}.ach-progress-bar{background:var(--border);border-radius:3px;height:6px;margin-bottom:.35rem;overflow:hidden}.ach-progress-fill{background:linear-gradient(90deg,gold,#f5a623);border-radius:3px;height:100%;transition:width .6s}.ach-progress-text{color:var(--text-muted);text-align:center;font-size:.7rem;font-weight:600}.feedback-overlay{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:9000;background:#000000b8;justify-content:center;align-items:center;padding:16px;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.feedback-modal{background:var(--surface,#1a1a2e);border-radius:20px;width:100%;max-width:380px;animation:.25s slideUp;overflow:hidden;box-shadow:0 24px 60px #00000080}.feedback-header{color:var(--text,#fff);border-bottom:1px solid #ffffff14;justify-content:space-between;align-items:center;padding:16px 20px;font-size:15px;font-weight:700;display:flex}.feedback-close{color:var(--text,#fff);cursor:pointer;background:#ffffff1a;border:none;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:14px;display:flex}.feedback-close:hover{background:#fff3}.feedback-body{flex-direction:column;gap:10px;padding:16px 20px;display:flex}.feedback-original,.feedback-result{color:var(--text-secondary,#aaa);gap:8px;font-size:.85rem;display:flex}.feedback-original label,.feedback-result label{color:var(--text-muted,#888);min-width:40px;font-weight:600}.feedback-original span,.feedback-result span{color:var(--text,#fff);font-weight:500}.feedback-text{width:100%;color:var(--text,#fff);resize:none;box-sizing:border-box;background:#ffffff0f;border:1.5px solid #ffffff1f;border-radius:12px;outline:none;padding:10px 12px;font-family:inherit;font-size:.9rem}.feedback-text:focus{border-color:var(--primary,#4f46e5);box-shadow:0 0 0 3px #4f46e526}.feedback-submit{color:#fff;cursor:pointer;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border:none;border-radius:14px;padding:12px;font-size:.95rem;font-weight:700;transition:all .2s}.feedback-submit:hover{opacity:.9;transform:translateY(-1px)}.stats-panel{z-index:50;margin-bottom:12px;position:sticky;top:0}.stats-toggle{background:var(--surface);border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;text-align:left;border-radius:14px;width:100%;padding:8px 16px;font-size:14px;font-weight:600;transition:all .2s}.stats-toggle:hover{border-color:var(--primary);color:var(--primary)}.stats-content{background:var(--surface);border:1px solid var(--border);text-align:left;border-radius:18px;margin-top:8px;padding:16px}.stats-mode-tabs{gap:6px;margin-bottom:16px;display:flex}.stats-mode-tab{border:1px solid var(--border);cursor:pointer;color:var(--text-secondary);background:0 0;border-radius:10px;flex:1;padding:8px 4px;font-size:13px;transition:all .2s}.stats-mode-tab.active{background:var(--primary);border-color:var(--primary);color:#fff;font-weight:700}.stats-mode-tab:not(.active):hover{border-color:var(--primary);color:var(--primary)}.stats-summary{gap:10px;margin-bottom:16px;display:flex}.stats-summary-card{background:var(--bg);border:1px solid var(--border);text-align:center;border-radius:12px;flex-direction:column;flex:1;gap:4px;padding:10px 8px;display:flex}.stats-summary-num{color:var(--primary);font-size:22px;font-weight:800}.stats-summary-label{color:var(--text-muted);font-size:11px}.stats-section{margin-bottom:14px}.stats-section-title{color:var(--text-secondary);margin-bottom:10px;font-size:13px;font-weight:600}.stats-trend-chart{align-items:flex-end;gap:4px;height:80px;padding:0 4px;display:flex}.stats-trend-bar-wrap{flex-direction:column;flex:1;justify-content:flex-end;align-items:center;gap:4px;height:100%;display:flex}.stats-trend-bar{background:linear-gradient(180deg, var(--accent), var(--accent-dark));border-radius:4px 4px 0 0;width:100%;max-width:28px;min-height:4px;transition:height .3s}.stats-trend-label{color:var(--text-muted);white-space:nowrap;font-size:9px}.stats-session-list{flex-direction:column;gap:6px;max-height:200px;display:flex;overflow-y:auto}.stats-session-item{background:var(--bg);border:1px solid var(--border);border-radius:10px;align-items:center;gap:8px;padding:6px 10px;display:flex}.stats-session-date{color:var(--text-muted);min-width:60px;font-size:11px}.stats-bar-track{background:var(--border);border-radius:3px;flex:1;height:6px;overflow:hidden}.stats-bar-fill{background:linear-gradient(90deg, var(--accent), var(--accent-dark));border-radius:3px;height:100%;transition:width .4s}.stats-session-accuracy{color:var(--primary);text-align:right;min-width:36px;font-size:13px;font-weight:700}.stats-session-score{color:var(--text-muted);text-align:right;min-width:36px;font-size:11px}.stats-empty{text-align:center;color:var(--text-muted);padding:20px}.stats-empty p{margin-bottom:4px;font-size:14px}.stats-empty-hint{opacity:.7;font-size:12px}.stats-clear-btn{border:1px solid var(--danger);color:var(--danger);cursor:pointer;background:0 0;border-radius:10px;width:100%;margin-top:8px;padding:6px 14px;font-size:12px;transition:all .2s}.stats-clear-btn:hover{background:var(--danger);color:#fff}.flashcard-result-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px;max-height:none;margin:12px 0;display:grid;overflow-y:visible}.flashcard-result-card{background:var(--surface);border:2px solid var(--border);cursor:pointer;text-align:center;border-radius:16px;flex-direction:column;justify-content:center;align-items:center;min-height:100px;padding:12px 10px;transition:all .2s;display:flex;position:relative}.flashcard-result-card.correct{border-color:var(--success);background:#34c7590f}.flashcard-result-card.wrong{border-color:var(--danger);background:#ef44440f}.flashcard-result-card.flipped .flashcard-result-front,.flashcard-result-card .flashcard-result-back{display:none}.flashcard-result-card.flipped .flashcard-result-back{flex-direction:column;align-items:center;gap:4px;display:flex}.flashcard-result-front{color:var(--text);font-size:14px;font-weight:600}.flashcard-result-back{color:var(--primary);font-size:15px;font-weight:700}.flashcard-result-back .result-card-roman{color:var(--text-secondary);font-size:11px}.flashcard-result-status{font-size:12px;position:absolute;top:6px;right:8px}.flashcard-result-hint{color:var(--text-muted);margin-top:4px;font-size:10px}.dictation-result-item{background:var(--surface);border:1px solid var(--border);text-align:left;border-radius:16px;margin-bottom:10px;padding:14px 16px}.dictation-result-item.correct{border-left:4px solid var(--success)}.dictation-result-item.wrong{border-left:4px solid var(--danger)}.dictation-result-audio{align-items:center;gap:8px;margin-bottom:8px;display:flex}.dictation-result-lo{color:var(--primary);flex:1;font-size:18px;font-weight:700}.dictation-result-replay{background:var(--primary-soft);cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:16px;transition:all .2s;display:flex}.dictation-result-replay:hover{background:var(--primary);transform:scale(1.1)}.dictation-result-replay.playing{animation:.6s ease-out pulse-ring}@keyframes pulse-ring{0%{box-shadow:0 0 0 0 rgba(var(--primary), .4)}to{box-shadow:0 0 0 12px rgba(var(--primary), 0)}}.dictation-result-answers{flex-wrap:wrap;gap:10px;margin-top:6px;display:flex}.dictation-result-answer{flex-direction:column;gap:2px;display:flex}.dictation-result-answer-label{color:var(--text-muted);text-transform:uppercase;font-size:10px}.dictation-result-your{color:var(--danger);font-size:14px;font-weight:600}.dictation-result-correct{color:var(--success);font-size:14px;font-weight:600}[data-theme=dark] .stats-content,[data-theme=dark] .stats-summary-card,[data-theme=dark] .stats-session-item,[data-theme=dark] .flashcard-result-card,[data-theme=dark] .dictation-result-item{background:#181d38cc;border-color:#8895ff24}[data-theme=dark] .stats-trend-bar{background:linear-gradient(180deg, var(--accent), var(--primary-dark))}[data-theme=dark] .stats-bar-fill{background:linear-gradient(90deg, var(--accent), var(--primary-dark))}[data-theme=dark] .flashcard-result-card.correct{background:#34c7591f}[data-theme=dark] .flashcard-result-card.wrong{background:#ef44441f}[data-theme=dark] .dictation-result-replay{background:#818cf833}[data-theme=dark] .dictation-result-replay:hover{background:var(--primary-dark)}[data-theme=dark] .result-item{background:#181d38d9;border-color:#8895ff24}[data-theme=dark] .result-item.correct{border-left-color:var(--success);background:#34c7591a}[data-theme=dark] .result-item.wrong{border-left-color:var(--danger);background:#ef44441a}[data-theme=dark] .result-tab:not(.active){color:var(--text-secondary);background:#181d38d9;border-color:#8895ff24}[data-theme=dark] .result-tab.active{background:var(--primary);border-color:var(--primary);color:#fff}[data-theme=dark] .result-list,[data-theme=dark] .result-item-q{color:var(--text)}[data-theme=dark] .result-item-correct{color:var(--success)}[data-theme=dark] .result-item-wrong{color:var(--danger)}[data-theme=dark] .result-item-roman{color:var(--text-secondary)}[data-theme=dark] .result-item-num{color:var(--text-muted)}[data-theme=dark] .no-wrong{color:var(--text-secondary)}[data-theme=dark] .correct-answer-hint{color:var(--success);background:#34c7591f;border-color:#34c7594d}.result-mini-bar{background:linear-gradient(135deg, var(--accent) 0%, var(--accent-dark) 100%);color:#fff;border-radius:14px;flex-wrap:wrap;justify-content:center;align-items:center;gap:12px;width:100%;max-width:340px;margin-bottom:16px;padding:10px 16px;font-size:15px;font-weight:700;display:flex;box-shadow:0 6px 16px #667eea40}.result-mini-score{opacity:.9}.result-mini-accuracy{color:#fff;text-shadow:0 1px 4px #0003;font-size:22px;font-weight:800}.result-mini-delta{background:#ffffff40;border-radius:20px;align-items:center;gap:2px;padding:3px 10px;font-size:13px;font-weight:600;display:flex}.result-mini-delta.up{background:#34c75959}.result-mini-delta.down{background:#ef444459}[data-theme=dark] .result-mini-bar{background:linear-gradient(135deg, var(--accent) 0%, var(--primary-dark) 100%);box-shadow:0 6px 20px #00000059}@media (width<=520px){.stats-panel{z-index:50;position:sticky;top:0}.stats-content{max-height:60vh;overflow-y:auto}}.result-card-lo{color:var(--primary);font-size:16px;font-weight:700}.result-quick-review{background:var(--bg);border:1px solid var(--border);border-radius:14px;flex-direction:column;gap:6px;width:100%;max-width:400px;margin-bottom:12px;padding:12px 16px;display:flex}.result-quick-label{color:var(--text-secondary);font-size:13px;font-weight:600}.result-quick-phrases{flex-wrap:wrap;gap:6px;display:flex}.result-quick-item{color:var(--danger);background:#ef444414;border:1px solid #ef444433;border-radius:8px;padding:4px 10px;font-size:14px;font-weight:600}.result-quick-more{color:var(--text-muted);align-self:center;padding:4px 8px;font-size:12px}[data-theme=dark] .result-quick-item{background:#ef444426;border-color:#ef44444d}.review-status-banner{background:linear-gradient(135deg, var(--accent) 0%, var(--accent-dark) 100%);color:#fff;border-radius:14px;align-items:center;gap:10px;max-width:340px;margin-bottom:12px;padding:10px 14px;display:flex}.review-status-icon{font-size:20px}.review-status-info{flex-direction:column;gap:2px;display:flex}.review-status-title{opacity:.9;font-size:13px;font-weight:700}.review-status-due{color:#ffe066;font-size:12px;font-weight:600}.review-status-done{opacity:.8;font-size:12px}[data-theme=dark] .review-status-banner{background:linear-gradient(135deg, var(--accent) 0%, var(--primary-dark) 100%);box-shadow:0 4px 12px #0000004d}.wordpacks-page{padding:0 16px 100px}.wordpacks-page .page-header{background:var(--bg);z-index:10;align-items:center;gap:12px;padding:16px 0;display:flex;position:sticky;top:0}.wordpacks-page .page-header h2{margin:0;font-size:18px}.wordpacks-page .back-btn{background:var(--card-bg);color:var(--text);cursor:pointer;border:none;border-radius:8px;padding:8px 16px;font-size:14px}.packs-section{margin-bottom:24px}.section-title{color:var(--text-secondary);margin-bottom:12px;padding-left:4px;font-size:14px}.wordpack-card{background:var(--card-bg);border-radius:12px;margin-bottom:12px;padding:16px}.wordpack-header{gap:12px;margin-bottom:12px;display:flex}.wordpack-lang-badge{background:var(--primary);color:#fff;border-radius:6px;height:fit-content;padding:4px 8px;font-size:12px;font-weight:600}.wordpack-title{margin:0 0 6px;font-size:16px}.wordpack-desc{color:var(--text-secondary);margin:0 0 8px;font-size:13px;line-height:1.4}.wordpack-meta{color:var(--text-secondary);gap:12px;font-size:12px;display:flex}.wordpack-meta .dl-badge{color:var(--success,#4caf50)}.wordpack-actions{gap:8px;display:flex}.wp-btn{cursor:pointer;border:none;border-radius:8px;flex:1;padding:10px 16px;font-size:14px;transition:opacity .2s}.wp-btn:disabled{opacity:.6;cursor:not-allowed}.wp-btn-download{background:var(--primary);color:#fff}.wp-btn-learn{background:var(--success,#4caf50);color:#fff}.wp-btn-delete{background:var(--card-bg);color:var(--text-secondary);border:1px solid var(--border);flex:none;padding:10px 12px}.loading{text-align:center;color:var(--text-secondary);padding:40px}.error-msg{color:#c00;background:#fee;border-radius:8px;margin:16px 0;padding:12px 16px}.empty-state{text-align:center;color:var(--text-secondary);padding:60px 20px}.page.wordbrowse-page{min-height:100vh;padding:0 0 6rem}.wb-header{border-bottom:1px solid var(--border);z-index:20;background:var(--bg);align-items:center;gap:.5rem;padding:.8rem 1rem;display:flex;position:sticky;top:0}.wb-title{flex:1;margin:0;font-size:1.1rem;font-weight:700}.back-btn{color:var(--text);cursor:pointer;background:0 0;border:none;border-radius:8px;padding:4px 8px;font-size:1rem}.back-btn:active{background:var(--surface)}.wb-learn-btn{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:20px;padding:6px 14px;font-size:.85rem}.wb-empty{text-align:center;flex-direction:column;align-items:center;padding:4rem 2rem;display:flex}.wb-empty-icon{margin-bottom:.5rem;font-size:3rem}.wb-empty p{margin:0;font-size:1rem;font-weight:500}.wb-empty-sub{color:var(--text-secondary);margin-top:.3rem!important;font-size:.85rem!important}.wb-pack-list{padding:.5rem 1rem}.wb-section-title{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;padding:.8rem 0 .4rem;font-size:.78rem;font-weight:700}.wb-pack-item{background:var(--surface);border:1px solid var(--border);cursor:pointer;border-radius:14px;align-items:center;gap:.75rem;margin-bottom:.5rem;padding:.9rem 1rem;transition:all .15s;display:flex}.wb-pack-item:active{background:var(--hover-bg);transform:scale(.98)}.wb-pack-icon{font-size:1.5rem}.wb-pack-body{flex:1}.wb-pack-name{font-size:1rem;font-weight:600}.wb-pack-desc{color:var(--text-secondary);margin-top:2px;font-size:.8rem}.wb-pack-arrow{color:var(--text-muted);font-size:1.3rem}.wb-search-bar{padding:.5rem 1rem 0}.wb-search-wrap{background:var(--surface);border:1.5px solid var(--border);border-radius:12px;align-items:center;gap:.5rem;padding:0 .75rem;display:flex}.wb-search-icon{color:var(--text-muted);flex-shrink:0;font-size:.9rem}.wb-search{color:var(--text);background:0 0;border:none;outline:none;flex:1;padding:10px 0;font-size:.95rem}.wb-search::placeholder{color:var(--text-muted)}.wb-search-clear{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:2px 4px;font-size:.8rem}.wb-count-bar{color:var(--text-secondary);gap:1rem;padding:.35rem .25rem;font-size:.78rem;display:flex}.wb-count-highlight{color:var(--primary);font-weight:600}.wb-card{background:var(--surface);border:1px solid var(--border);text-align:center;cursor:pointer;border-radius:20px;margin:1rem;padding:1.8rem 1.5rem;position:relative;box-shadow:0 2px 16px #00000012}.wb-card-word{color:var(--text);letter-spacing:.02em;margin-bottom:.25rem;font-size:2.2rem;font-weight:800}.wb-card-pinyin{color:var(--text-muted);margin-bottom:.5rem;font-size:.85rem}.wb-card-zh{color:var(--text-secondary);margin-bottom:.25rem;font-size:1.35rem}.wb-card-en{color:var(--text-muted);font-size:.82rem}.wb-card-actions{justify-content:center;gap:.8rem;margin-top:1.2rem;display:flex}.wb-action-btn{border:1.5px solid var(--border);background:var(--surface);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;font-size:1.1rem;transition:all .15s;display:flex}.wb-action-btn:active{transform:scale(.9)}.wb-action-btn.active{background:#e91e6314;border-color:#e91e63}.wb-action-btn.playing{border-color:var(--primary);background:#4a90d914}.wb-nav{justify-content:center;align-items:center;gap:1.5rem;padding:.8rem 1rem;display:flex}.wb-nav-btn{border:1.5px solid var(--border);background:var(--surface);cursor:pointer;width:44px;height:44px;color:var(--text);border-radius:50%;justify-content:center;align-items:center;font-size:1.4rem;display:flex}.wb-nav-btn:active:not(:disabled){transform:scale(.93)}.wb-nav-btn:disabled{opacity:.3;cursor:not-allowed}.wb-counter{color:var(--text-secondary);text-align:center;min-width:70px;font-size:.9rem}.wb-list-section{padding:0 1rem 2rem}.wb-list{border:1px solid var(--border);border-radius:14px;max-height:45vh;overflow:hidden auto}.wb-list-item{border-bottom:1px solid var(--border);background:var(--surface);cursor:pointer;justify-content:space-between;align-items:center;padding:.75rem .85rem;transition:background .1s;display:flex}.wb-list-item:last-child{border-bottom:none}.wb-list-item.active{background:#4a90d914}.wb-list-item:active{background:var(--hover-bg)}.wb-list-main{flex-direction:column;flex:1;gap:1px;display:flex}.wb-list-lo{font-size:.98rem;font-weight:600}.wb-list-zh{color:var(--text-secondary);font-size:.85rem}.wb-list-actions{align-items:center;gap:.3rem;display:flex}.wb-list-btn{cursor:pointer;background:0 0;border:none;border-radius:6px;padding:4px 5px;font-size:.9rem}.wb-list-btn:active{background:var(--surface)}.wb-list-btn.faved{color:#e91e63}.share-preview-overlay{align-items:flex-end;padding:0}.share-preview-modal{border-radius:24px 24px 0 0;max-width:100%;max-height:95vh;overflow-y:auto}@media (width>=500px){.share-preview-overlay{align-items:center}.share-preview-modal{border-radius:24px}}.share-channel-grid{grid-template-columns:repeat(3,1fr);gap:8px;padding:0 12px 20px}.share-channel-btn{border-radius:14px;padding:12px 6px}.channel-icon{font-size:22px}.channel-name{font-size:11px}.tp-history-dropdown{background:var(--surface);border:1px solid var(--border);z-index:100;border-radius:0 0 14px 14px;max-height:280px;position:absolute;top:100%;left:0;right:0;overflow:hidden auto;box-shadow:0 4px 16px #0000001f}.tp-history-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;padding:8px 14px 4px;font-size:.75rem;font-weight:600}.tp-history-item{cursor:pointer;justify-content:space-between;align-items:center;padding:8px 14px;display:flex}.tp-history-item:hover{background:var(--hover-bg)}.tp-history-text{color:var(--text);font-size:.95rem}.tp-history-del{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:2px 4px;font-size:.75rem}.tp-history-clear{border:none;border-top:1px solid var(--border);width:100%;color:var(--text-muted);cursor:pointer;text-align:center;background:0 0;padding:8px;font-size:.85rem}.tp-history-clear:hover{color:var(--text)}.tp-pack-filter{scrollbar-width:none;gap:6px;padding:.4rem 1rem;display:flex;overflow-x:auto}.tp-pack-filter::-webkit-scrollbar{display:none}.tp-pack-btn{border:1.5px solid var(--border);background:var(--surface);color:var(--text-secondary);cursor:pointer;white-space:nowrap;border-radius:16px;flex-shrink:0;padding:4px 12px;font-size:.8rem}.tp-pack-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.phrase-pinyin{color:var(--text-muted);margin-bottom:2px;font-size:.78rem}.phrase-copy{cursor:pointer;background:0 0;border:none;border-radius:6px;padding:4px 6px;font-size:.85rem}.phrase-copy:hover{background:#0000000f}.tp-filter-tag{background:var(--primary);color:#fff;border-radius:10px;margin-left:8px;padding:2px 8px;font-size:.75rem}
