:root{--text: #6b6375;--text-h: #08060d;--bg: #fff;--border: #e5e4e7;--code-bg: #f4f3ec;--accent: #aa3bff;--accent-bg: rgba(170, 59, 255, .1);--accent-border: rgba(170, 59, 255, .5);--social-bg: rgba(244, 243, 236, .5);--shadow: rgba(0, 0, 0, .1) 0 10px 15px -3px, rgba(0, 0, 0, .05) 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;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 (max-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: rgba(192, 132, 252, .15);--accent-border: rgba(192, 132, 252, .5);--social-bg: rgba(47, 48, 58, .5);--shadow: rgba(0, 0, 0, .4) 0 10px 15px -3px, rgba(0, 0, 0, .25) 0 4px 6px -2px}#social .button-icon{filter:invert(1) brightness(2)}}body{margin:0}#root{width:1126px;max-width:100%;margin:0 auto;text-align:center;border-inline:1px solid var(--border);min-height:100svh;display:flex;flex-direction:column;box-sizing:border-box}h1,h2{font-family:var(--heading);font-weight:500;color:var(--text-h)}h1{font-size:56px;letter-spacing:-1.68px;margin:32px 0}@media (max-width: 1024px){h1{font-size:36px;margin:20px 0}}h2{font-size:24px;line-height:118%;letter-spacing:-.24px;margin:0 0 8px}@media (max-width: 1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);display:inline-flex;border-radius:4px;color:var(--text-h)}code{font-size:15px;line-height:135%;padding:4px 8px;background:var(--code-bg)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--primary: #007AFF;--primary-dark: #0056CC;--primary-glow: rgba(0, 122, 255, .25);--primary-soft: rgba(0, 122, 255, .1);--accent: #667eff;--accent-dark: #4f97ff;--page-gutter: 1rem;--bg: #F2F2F7;--bg-secondary: #E5E5EA;--surface: #ffffff;--surface-hover: #F5F5FA;--text: #000000;--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 rgba(0,0,0,.04), 0 1px 2px rgba(0,0,0,.06);--shadow-md: 0 4px 12px rgba(0,0,0,.08), 0 2px 4px rgba(0,0,0,.04);--shadow-lg: 0 10px 30px rgba(0,0,0,.1), 0 4px 10px rgba(0,0,0,.06);--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: rgba(102, 126, 234, .18);--border-light: rgba(102, 126, 234, .1);--primary: #0A84FF;--primary-dark: #409CFF;--primary-glow: rgba(129, 140, 248, .25);--primary-soft: rgba(129, 140, 248, .1);--accent: #8b95ff;--accent-dark: #6ab0ff;--hot-bg: #1c1208;--hot-border: #78350f;--shadow: 0 4px 20px rgba(0, 0, 0, .4);--shadow-md: 0 8px 32px rgba(0, 0, 0, .5);--shadow-lg: 0 16px 48px rgba(0, 0, 0, .6)}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{min-height:100vh;min-height:calc(var(--vh, 1) * 100);font-family:Noto Sans Lao,Noto Sans,-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;background:linear-gradient(180deg,#f2f2f7,#e8e8ed,#f2f2f7);color:var(--text);min-height:100dvh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background-color .25s ease,color .25s ease,border-color .25s ease,box-shadow .25s ease}*,*:before,*:after{transition:background-color .25s ease,color .25s ease,border-color .25s ease}[data-theme=dark] body{background:linear-gradient(180deg,#0d0f23,#141632,#0d0f23)}.splash-screen{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--bg);gap:20px}.splash-logo{display:flex;flex-direction:column;align-items:center;gap:10px;animation:splash-pulse 1.6s ease-in-out infinite}.splash-logo-img{width:72px;height:72px;border-radius:18px;object-fit:cover;box-shadow:0 8px 32px #0000002e}.splash-title{font-size:26px;font-weight:800;color:var(--primary);letter-spacing:-.5px}.splash-subtitle{font-size:13px;color:var(--text-muted);letter-spacing:.08em;text-transform:uppercase}.splash-dots{display:flex;gap:8px;margin-top:4px}.splash-dot{width:7px;height:7px;border-radius:50%;background:var(--primary);opacity:.35;animation:splash-dot-bounce 1.2s ease-in-out infinite}.splash-dot:nth-child(2){animation-delay:.2s}.splash-dot:nth-child(3){animation-delay:.4s}.splash-bar{width:140px;height:3px;border-radius:2px;background:var(--border);overflow:hidden;margin-top:8px}.splash-bar-fill{height:100%;border-radius:2px;background:var(--primary);animation:splash-progress 2.5s ease-out forwards}@keyframes splash-pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.04);opacity:.88}}@keyframes splash-dot-bounce{0%,to{transform:translateY(0);opacity:.35}50%{transform:translateY(-6px);opacity:1}}@keyframes splash-progress{0%{width:0%}60%{width:85%}to{width:100%}}.app{width:100%;max-width:520px;margin:0 auto;min-height:100dvh;padding-bottom:100px}.main-content{width:100%}.hdr{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;position:sticky;top:0;z-index:200;box-shadow:0 4px 20px #667eea66;border-radius:0 0 24px 24px;padding:0 1.25rem;transition:background .3s ease}.hdr-inner{display:flex;align-items:center;justify-content:space-between;height:var(--hdr-h)}.hdr-brand{display:flex;align-items:center;gap:.75rem;flex-shrink:0}.hdr-logo{width:48px;height:42px;border-radius:20%;flex-shrink:0;display:flex;align-items:center;justify-content:center}.hdr-logo-img{width:100%;height:100%;object-fit:contain;border-radius:20%}.hdr-sub{font-size:.72rem;opacity:.8;font-weight:500;margin-top:1px}.hdr-actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.stats-bar{display:flex;justify-content:center;gap:1.5rem;padding:.4rem 1rem;background:#667eea14;border-bottom:1px solid rgba(102,126,234,.1);font-size:.78rem;color:var(--text-secondary)}.stats-bar b{color:var(--primary);font-weight:700}.locale-toggle{display:flex;background:#0000000d;border-radius:20px;padding:3px;gap:2px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.locale-btn{padding:4px 10px;border-radius:16px;border:none;background:transparent;color:#ffffffb3;font-size:.75rem;font-weight:700;cursor:pointer;transition:all .2s;letter-spacing:.04em}.locale-btn.active{background:var(--surface);color:var(--primary);box-shadow:0 2px 8px #00000026}.locale-btn:active{transform:scale(.92)}.hdr-icon-btn{width:48px;height:48px;border-radius:50%;border:none;background:#0000000f;color:#4b4664e6;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.hdr-icon-btn:active{transform:scale(.88)}.hdr-icon-btn.active{background:#fffffff2;color:var(--primary)}.panel-open{max-height:800px;opacity:1}.trans-wrap,.settings-wrap{margin:.75rem 1rem;background:#ffffffb8;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:20px;padding:1.25rem;box-shadow:0 8px 32px #00000014,0 1px 2px #0000000a,inset 0 1px #fff9;border:1px solid rgba(102,126,234,.12);animation:panelIn .35s cubic-bezier(.25,.46,.45,.94)}[data-theme=dark] .trans-wrap,[data-theme=dark] .settings-wrap{background:#1e2236c7;border:1px solid rgba(102,126,234,.15);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{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.trans-title{font-size:.8rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em}.trans-row{display:flex;align-items:center;gap:.5rem;margin-bottom:.6rem}.trans-arrow{color:var(--text-muted);flex-shrink:0}.trans-lang-select{flex:1;padding:.45rem .6rem;border-radius:var(--radius-xs);border:1.5px solid var(--border);background:var(--bg);color:var(--text);font-size:.85rem;font-weight:600;cursor:pointer;-moz-appearance:none;appearance:none;-webkit-appearance:none;outline:none;transition:border-color .2s}.trans-lang-select:focus{border-color:var(--primary)}.trans-input{width:100%;padding:.65rem .85rem;border-radius:var(--radius-xs);border:1.5px solid var(--border);background:var(--bg);color:var(--text);font-size:.95rem;font-family:inherit;resize:none;outline:none;margin-bottom:.6rem;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:pulse 1s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.trans-submit-btn{width:100%;padding:.75rem 1rem;border-radius:12px;border:none;background:linear-gradient(135deg,#007aff,#0056cc);color:#fff;font-size:1rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 16px #007aff59,inset 0 1px #ffffff26}.trans-submit-btn:active{transform:scale(.97);background:linear-gradient(135deg,#0056cc,#049);box-shadow:0 2px 8px #007aff40,inset 0 1px #ffffff1a}.trans-submit-btn:disabled{opacity:.5;cursor:not-allowed;transform:none;background:linear-gradient(135deg,#a0a0a0,gray);box-shadow:none}.trans-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}.trans-result-box{margin-top:.75rem;padding:.85rem;background:linear-gradient(135deg,var(--primary-soft),transparent);border-radius:var(--radius-xs);border:1.5px solid var(--border-light)}.trans-result-lo{font-size:1.25rem;font-weight:700;color:var(--primary);margin-bottom:.6rem;line-height:1.4}.trans-result-actions{display:flex;gap:.5rem}.trans-play-btn,.trans-action-btn{display:flex;align-items:center;gap:.35rem;padding:0 1.1rem;border-radius:20px;border:1.5px solid var(--border);background:var(--surface);color:var(--text-secondary);font-size:.78rem;font-weight:600;cursor:pointer;transition:all .2s}.trans-play-btn:active,.trans-action-btn:active{transform:scale(.95)}.trans-play-btn:hover,.trans-action-btn:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-soft)}.trans-history{margin-top:.85rem;border-top:1px solid var(--border);padding-top:.75rem}.trans-history-title{font-size:.75rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.5rem}.trans-history-item{display:flex;align-items:center;gap:.5rem;padding:.45rem .6rem;border-radius:var(--radius-xs);background:var(--bg);margin-bottom:.35rem;cursor:pointer;transition:background .2s;position:relative}.trans-history-item:active{background:var(--primary-soft)}.trans-history-from{flex:1;font-size:.82rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.trans-history-arrow{color:var(--text-muted);font-size:.75rem;flex-shrink:0}.trans-history-to{font-size:.88rem;font-weight:700;color:var(--primary);max-width:120px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex-shrink:0}.history-del-btn{margin-left:auto;background:none;border:none;color:var(--text-muted);font-size:1rem;cursor:pointer;padding:2px 6px;border-radius:6px;flex-shrink:0;opacity:0;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{font-size:.75rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.5rem}.lang-chips{display:flex;flex-wrap:wrap;gap:.4rem}.lang-chip{display:inline-flex;align-items:center;gap:.3rem;padding:.45rem .9rem;border-radius:22px;border:none;background:#667eea14;color:var(--text-secondary);font-size:.8rem;font-weight:500;cursor:pointer;transition:all .2s}[data-theme=dark] .lang-chip{background:#667eea26}.lang-chip:hover{background:#667eea26;color:var(--text)}.lang-chip.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-weight:600;box-shadow:0 2px 8px #667eea4d}.lang-chip:active{transform:scale(.95)}.search-area{display:none!important}.search-box{display:flex;align-items:center;gap:.6rem;background:var(--surface);border-radius:18px;padding:0 .85rem;box-shadow:var(--shadow);border:2px solid transparent;transition:all .25s}.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{flex:1;border:none;outline:none;background:transparent;font-size:.95rem;color:var(--text);padding:.85rem 0;font-family:inherit}.search-input::placeholder{color:var(--text-muted)}.search-clear{width:26px;height:26px;border-radius:50%;border:none;background:var(--bg-secondary);color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s}.search-clear:hover{background:var(--danger);color:#fff}.search-clear:active{transform:scale(.88)}.tab-bar{display:flex;gap:6px;padding:.75rem 1rem 0;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.tab-bar::-webkit-scrollbar{display:none}.tab-btn{flex-shrink:0;display:inline-flex;align-items:center;gap:.4rem;padding:.55rem 1rem;border-radius:20px;border:none;background:var(--surface);color:var(--text-secondary);font-size:.85rem;font-weight:700;cursor:pointer;transition:all .25s;box-shadow:var(--shadow);white-space:nowrap;letter-spacing:.01em}.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{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 4px;border-radius:9px;background:#ffffff4d;color:inherit;font-size:.68rem;font-weight:800}.tab-btn:not(.active) .tab-badge{background:var(--primary-soft);color:var(--primary)}.cats-scroll{display:flex;gap:8px;padding:.6rem 1rem .5rem;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.cat-pill{flex-shrink:0;display:inline-flex;align-items:center;gap:.3rem;padding:.4rem .9rem;border-radius:16px;border:1.5px solid var(--border);background:var(--surface);color:var(--text-secondary);font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 2px 8px #0000000a;white-space:nowrap}.cat-pill:active{transform:scale(.95)}.cat-pill.active{background:var(--primary);color:#fff;border-color:transparent;box-shadow:0 4px 12px var(--primary-glow)}.cat-locked{opacity:.5;text-decoration:line-through}.cat-loading{opacity:.6}.cat-count{font-size:.7rem;opacity:.7;font-weight:500}.phrase-list{padding:.5rem var(--page-gutter) 2rem;display:flex;flex-direction:column;gap:.75rem}.phrase-card{background:linear-gradient(135deg,#fff,#f8f9ff);border-radius:18px;padding:1rem 1rem .95rem;box-shadow:0 2px 8px #0000000a,0 4px 16px #667eea14;border:1px solid rgba(102,126,234,.1);transition:all .25s;animation:cardIn .3s ease both;min-height:88px}[data-theme=dark] .phrase-card{background:linear-gradient(135deg,#1a1e3a,#202448);border:1px solid rgba(102,126,234,.15);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{transform:scale(.985);box-shadow:var(--shadow-md)}.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{display:flex;align-items:center;gap:.6rem;margin-bottom:.75rem}.card-lao{flex:1;font-size:1.4rem;font-weight:800;color:var(--primary);cursor:pointer;line-height:1.35;letter-spacing:.01em;transition:opacity .2s;min-width:0}.card-lao:hover{opacity:.75}.card-lao:active{opacity:.5}.card-roman{font-size:.85rem;color:var(--text-secondary);font-style:italic;padding:2px 0;margin-top:-.25rem;margin-bottom:.25rem}.card-actions{display:flex;gap:.4rem;flex-shrink:0}.card-play-btn,.card-fav-btn{width:48px;height:48px;border-radius:50%;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}.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:playPulse 1s ease infinite}@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{background:#f43f5e1a;color:var(--fav-color)}.card-share-btn{background:var(--bg-secondary);color:var(--text-muted);border:none;border-radius:8px;width:30px;height:30px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;flex-shrink:0}.card-share-btn:hover{background:#4f46e51f;color:var(--primary)}.card-share-btn:active{transform:scale(.85)}.card-trans{display:flex;flex-direction:column;gap:.3rem;margin-bottom:.5rem}.card-trans-item{display:flex;align-items:baseline;gap:.5rem}.trans-lang-label{font-size:.65rem;font-weight:800;letter-spacing:.06em;padding:1px 6px;border-radius:6px;opacity:.75;flex-shrink:0}.tag-zh .trans-lang-label{background:#dc26261f;color:#dc2626}.tag-en .trans-lang-label{background:#2563eb1f;color:#2563eb}.tag-th .trans-lang-label{background:#9333ea1f;color:#9333ea}.tag-vi .trans-lang-label{background:#ca8a041f;color:#ca8a04}.tag-lo .trans-lang-label{background:#667eea1f;color:var(--primary)}.trans-text{font-size:.92rem;color:var(--text);line-height:1.45;word-break:break-word}.card-category{display:inline-flex;align-items:center;gap:.3rem;font-size:.72rem;color:var(--text-muted);font-weight:600;padding:.2rem .6rem;background:var(--bg-secondary);border-radius:8px;margin-top:.25rem;width:fit-content}.cat-hot-count{color:var(--warning);font-weight:700}.empty-state{text-align:center;padding:3.5rem 1rem;animation:cardIn .3s ease}.empty-icon{font-size:3.5rem;margin-bottom:.85rem;opacity:.5;filter:grayscale(.3)}.empty-state p{color:var(--text-secondary);font-size:.9rem;font-weight:500;margin:.3rem 0}.empty-title{font-weight:700!important;font-size:1rem!important;color:var(--text)!important}.empty-sub{font-size:.82rem!important;opacity:.7}.clear-history-btn{margin-top:.75rem;padding:.45rem 1rem;border-radius:20px;border:1.5px solid var(--danger);background:transparent;color:var(--danger);font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s}.clear-history-btn:hover{background:#ef444414}.clear-history-btn:active{transform:scale(.95)}.loading-spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto .75rem}.toast{position:fixed;bottom:28px;left:50%;transform:translate(-50%);background:linear-gradient(135deg,#1a1d3b,#2d3260);color:#fff;padding:.65rem 1.25rem;border-radius:24px;font-size:.85rem;font-weight:600;z-index:9999;box-shadow:0 8px 32px #00000059;display:flex;align-items:center;gap:.5rem;animation:toastIn .25s cubic-bezier(.4,0,.2,1);white-space:nowrap;pointer-events:none}[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 (max-width: 480px){:root{--page-gutter: .75rem;--hdr-h: 58px}.app{max-width:100%;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{padding:.9rem .9rem .8rem;border-radius:16px}.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 (min-width: 600px){.app{max-width:520px;width:100%;padding-top:1rem}.hdr{border-radius:var(--radius);margin:.5rem .75rem;position:static}}@media (min-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-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:1000;display:flex;align-items:center;justify-content:center;padding:1rem}.modal-box{background:var(--surface);border-radius:var(--radius);padding:1.5rem;width:100%;max-width:320px;position:relative;box-shadow:var(--shadow)}.login-input{width:100%;padding:.65rem .85rem;border:2px solid var(--border);border-radius:var(--radius-xs);background:var(--bg);color:var(--text);font-size:.95rem;outline:none;box-sizing:border-box}.login-input:focus{border-color:var(--primary)}.login-btn{width:100%;padding:.65rem;background:var(--primary);color:#fff;border:none;border-radius:var(--radius-xs);font-size:.95rem;font-weight:600;cursor:pointer}.login-btn:active{transform:scale(.97)}.fav-section-label{display:flex;align-items:center;gap:8px;padding:8px 4px 4px;font-size:12px;color:var(--text-secondary);font-weight:600}.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{min-height:100dvh;min-height:100vh;overscroll-behavior-y:contain}.visit-counter{text-align:center;padding:10px;margin:0 12px 8px;font-size:13px;color:var(--text-secondary);background:var(--surface);border-radius:8px;border:1px solid var(--border)}.bottom-nav{position:fixed;bottom:0;left:0;right:0;z-index:500;background:#ffffffeb;display:flex;align-items:center;justify-content:space-around;padding-bottom:env(safe-area-inset-bottom,0px);box-sizing:border-box;backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px);box-shadow:0 -1px 0 var(--border-light);transform:translateY(0);transition:transform .3s cubic-bezier(.32,.72,0,1);overflow:hidden}.nav-hidden{transform:translateY(100%)}.nav-visible{transform:translateY(0)}.nav-item{position:relative;flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:4px;border:none;background:none;cursor:pointer;color:var(--text-muted);font-size:11px;font-family:inherit;transition:color .2s ease,transform .15s ease;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.nav-item:active{transform:scale(.92);color:var(--primary)}.nav-item.active:after{content:"";position:absolute;bottom:6px;left:50%;transform:translate(-50%);width:20px;height:3px;border-radius:2px;background:var(--primary)}.nav-item svg{width:22px;height:22px;flex-shrink:0}.nav-item span{font-weight:600;letter-spacing:.02em}.toast{bottom:calc(60px + env(safe-area-inset-bottom,0px));backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.hdr-icon-btn{min-width:40px;min-height:40px;will-change:transform}.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 ease}.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{animation-duration:.01ms!important;transition-duration:.01ms!important}}@media (max-height: 500px) and (orientation: landscape){.app{padding-top:0}.bottom-nav{width:100%;left:0;right:0;border-radius:0}.app{padding-bottom:20px}}@media (min-width: 600px){.bottom-nav{width:min(100%,520px);left:50%;right:auto;transform:translate(-50%);border-radius:22px 22px 0 0}.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{background:transparent;color:var(--text)}[data-theme=dark] mark{background:#818cf840;color:var(--primary)}[data-theme=dark] .tab-badge{background:var(--primary);color:#fff}mark{border-radius:2px;padding:0 1px;font-style:normal}.fav-sort-bar{display:flex;gap:6px;margin-bottom:12px;flex-wrap:wrap;align-items:center}.fav-sort-btn{padding:5px 12px;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--text-secondary);font-size:12px;font-family:inherit;cursor:pointer;transition:all .2s}.apple-export-btn{width:100%;padding:.7rem 1.25rem;background:var(--primary);color:#fff;border:none;border-radius:var(--radius-sm);font-size:.9rem;font-weight:600;font-family:inherit;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.5rem;margin:.5rem 1rem .25rem;transition:all .2s;letter-spacing:-.01em}.export-fav-btn{width:100%;padding:10px 16px;background:var(--primary);color:#fff;border:none;border-radius:12px;font-size:14px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;font-family:inherit;margin-bottom:8px}.fav-sort-row{display:flex;gap:6px;flex-wrap:wrap}.trans-result-box{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:16px 20px;margin:12px 0;animation:slideDown .2s ease}.trans-result-lo{font-size:22px;font-weight:700;color:var(--primary);margin-bottom:12px;line-height:1.4;word-break:break-word}.trans-result-actions{display:flex;gap:8px;align-items:center}.trans-play-btn,.trans-action-btn{display:flex;align-items:center;justify-content:center;gap:6px;border:1.5px solid var(--border);border-radius:10px;background:var(--surface);color:var(--text-secondary);cursor:pointer;transition:all .18s ease;font-family:inherit;min-width:44px;min-height:44px;padding:0 14px}.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{display:flex;gap:6px;align-items:center;flex-shrink:0}.play-btn,.fav-btn{display:flex;align-items:center;justify-content:center;border:1.5px solid var(--border);border-radius:10px;background:var(--surface);color:var(--text-secondary);cursor:pointer;width:48px;height:48px;padding:0;transition:all .18s ease;flex-shrink:0}.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);border-color:#667eea4d;color:var(--text-secondary)}.admin-standalone{display:none!important}.admin-login-wrap{background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:40px 36px;width:100%;max-width:400px;box-shadow:0 20px 60px #0000001a}.admin-login-wrap h2{text-align:center;margin-bottom:28px;color:var(--text);font-size:20px}.admin-login-wrap .login-input{width:100%;padding:14px 16px;border:1.5px solid var(--border);border-radius:12px;background:var(--bg);color:var(--text);font-size:15px;margin-bottom:16px;box-sizing:border-box;font-family:inherit}.admin-login-wrap .login-btn{width:100%;padding:14px;background:var(--primary);color:#fff;border:none;border-radius:12px;font-size:15px;font-weight:600;cursor:pointer;font-family:inherit;transition:transform .15s ease}.admin-login-wrap .login-btn:active{transform:scale(.97)}.fav-sort-bar{display:flex;gap:6px;margin-bottom:12px;flex-wrap:wrap}.fav-sort-btn{padding:5px 12px;border:1.5px solid var(--border);border-radius:8px;background:var(--surface);color:var(--text-secondary);font-size:12px;font-family:inherit;cursor:pointer;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{background:#1a1e3af2;color:var(--text);border-color:#667eea33}[data-theme=dark] .bottom-nav{background:#1a1e3af2;border-top-color:#667eea26;backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px)}[data-theme=dark] .nav-item{color:#fff9}[data-theme=dark] .nav-item.active{color:#818cf8e6}[data-theme=dark] .apple-export-btn{width:100%;padding:.7rem 1.25rem;background:var(--primary);color:#fff;border:none;border-radius:var(--radius-sm);font-size:.9rem;font-weight:600;font-family:inherit;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.5rem;margin:.5rem 1rem .25rem;transition:all .2s;letter-spacing:-.01em}.apple-export-btn:hover{opacity:.88}.apple-export-btn:active{opacity:.65}.fav-group-title{font-size:.75rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;padding:1rem 1rem .25rem}.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{width:100%;padding:.75rem 1rem;background:var(--primary);color:#fff;border:none;border-radius:var(--radius-xs);font-size:.85rem;font-weight:600;font-family:inherit;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.5rem;margin-bottom:.5rem;transition:all .2s}.export-fav-btn{background:linear-gradient(135deg,#667eeae6,#764ba2e6);border:1px solid rgba(102,126,234,.4)}[data-theme=dark] .fav-sort-btn{background:#1e233ccc;border-color:#667eea40;color:#fff9}[data-theme=dark] .fav-sort-btn.active{background:#667eeacc;border-color:#667eea80;color:#fff}.phrase-card:active{background:var(--primary-soft)}.cats-scroll{gap:8px;padding:4px 16px}.search-input{min-height:44px;font-size:16px}.empty-state{padding:48px 20px;text-align:center}.empty-state .empty-icon{font-size:48px;margin-bottom:12px}.empty-state p{color:var(--text-secondary);font-size:14px}@keyframes shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}.skeleton-card{animation:none;pointer-events:none}.skeleton-line{background:linear-gradient(90deg,var(--border) 25%,var(--surface-hover) 50%,var(--border) 75%);background-size:800px 100%;animation:shimmer 1.5s infinite;border-radius:6px;display:block}[data-theme=dark] .skeleton-line{background:linear-gradient(90deg,#667eea14 25%,#667eea26,#667eea14 75%);background-size:800px 100%}.skeleton-list{display:flex;flex-direction:column;gap:8px;padding:0 16px}.loading-spinner,.trans-history-search{display:none!important}.announcement-bar{margin:8px 12px;padding:12px 14px;background:var(--surface);border:1px solid var(--border);border-radius:12px;font-size:13px;line-height:1.7;box-shadow:var(--shadow)}.announcement-title{font-weight:700;font-size:14px;margin-bottom:6px;color:var(--primary)}.announcement-body{color:var(--text-secondary);margin-bottom:4px;font-size:12px}.announcement-section{font-weight:700;font-size:12px;color:var(--text);margin-top:4px;margin-bottom:2px}.announcement-item{padding-left:8px;font-size:12px;color:var(--text-secondary);line-height:1.6}.announcement-item a{color:var(--primary);text-decoration:none;font-weight:500}.announcement-item a:hover{text-decoration:underline}.quick-translate-card{margin:.75rem;padding:1rem;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;color:#fff}.quick-translate-title{font-size:.9rem;font-weight:600;margin-bottom:.75rem}.quick-translate-input-row{display:flex;gap:.5rem}.quick-translate-input{flex:1;padding:.6rem .8rem;border:none;border-radius:10px;font-size:.9rem;background:#ffffffe6;color:#333}.quick-translate-btn{padding:.6rem 1rem;border:none;border-radius:10px;background:#fff;color:#667eea;font-weight:600;cursor:pointer}.quick-translate-result{margin-top:.75rem;padding:.75rem;background:#ffffff26;border-radius:10px;display:flex;justify-content:space-between;align-items:center}.lo-text{font-size:1.1rem;font-weight:500}.copy-btn{background:none;border:none;font-size:1.2rem;cursor:pointer;opacity:.8}.quick-ai-btn{padding:.55rem .75rem;border:1.5px solid rgba(255,255,255,.35);border-radius:10px;background:#ffffff1a;color:#ffffffb3;font-size:.8rem;font-weight:700;cursor:pointer;transition:all .2s;white-space:nowrap}.quick-ai-btn.active{background:#ffffff40;border-color:#ffffffb3;color:#fff;box-shadow:0 0 12px #ffffff4d}.quick-result-local,.quick-result-ai{display:flex;align-items:center;gap:8px;flex-wrap:wrap;flex:1}.quick-result-lo{font-size:1.2rem;font-weight:800;color:#fff}.quick-result-sep{color:#fff9;font-size:1rem}.quick-result-zh{font-size:1rem;color:#ffffffe6;font-weight:600}.quick-result-en{font-size:.85rem;color:#ffffffa6;font-style:italic}.quick-result-tag{font-size:.7rem;padding:2px 8px;border-radius:20px;background:#fff3;color:#ffffffe6;font-weight:700;margin-left:auto}.quick-no-result{margin-top:.6rem;font-size:.8rem;color:#ffffff8c;text-align:center;font-style:italic}.search-history-dropdown{position:absolute;top:100%;left:0;right:0;margin-top:6px;background:var(--surface);border:1.5px solid var(--border);border-radius:14px;box-shadow:0 8px 24px #0000001f;z-index:200;overflow:hidden}.search-history-header{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;font-size:.78rem;color:var(--text-muted);border-bottom:1px solid var(--border)}.clear-history-btn{background:none;border:none;color:var(--primary);cursor:pointer;font-size:.78rem}.search-history-item{display:flex;align-items:center;gap:10px;padding:10px 14px;cursor:pointer;transition:background .15s;font-size:.9rem;color:var(--text)}.search-history-item:hover{background:var(--bg-secondary)}.history-icon{font-size:.85rem;opacity:.6}.search-clear-btn{position:absolute;right:148px;top:50%;transform:translateY(-50%);background:#fffc;border:none;border-radius:50%;width:26px;height:26px;color:var(--text-muted);cursor:pointer;font-size:.75rem;display:flex;align-items:center;justify-content:center;z-index:10}.quick-results-list{margin-top:.75rem;display:flex;flex-direction:column;gap:8px}.quick-result-item{display:flex;flex-direction:column;gap:6px;padding:.85rem .95rem;border-radius:14px;border:1px solid rgba(255,255,255,.15);background:#ffffff1a;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.quick-result-main{display:flex;align-items:baseline;gap:10px}.quick-result-lo{font-size:1.3rem;font-weight:800;color:var(--primary)}.quick-result-roman{font-size:.78rem;color:#f5a623;font-style:italic;font-weight:600;text-transform:uppercase}.quick-result-details{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.quick-result-zh{font-size:.9rem;color:var(--text);font-weight:600}.quick-result-en{font-size:.85rem;color:var(--text-secondary)}.quick-result-source{font-size:.68rem;padding:2px 8px;border-radius:20px;background:#4f46e51f;color:var(--primary);font-weight:600}.quick-result-actions{display:flex;gap:8px;margin-top:4px}.quick-action-btn{width:34px;height:34px;border-radius:10px;border:none;background:#ffffff26;cursor:pointer;font-size:.9rem;display:flex;align-items:center;justify-content:center;transition:all .2s}.quick-action-btn:hover{background:#ffffff40;transform:scale(1.05)}.quick-action-btn.active{background:#ff000026}.daily-word-card{margin:.75rem;padding:1.25rem;background:linear-gradient(135deg,#11998e,#38ef7d);border-radius:16px;color:#fff;text-align:center}.daily-word-label{font-size:.8rem;opacity:.9;margin-bottom:.5rem}.daily-word-content{display:flex;align-items:center;justify-content:center;gap:1rem}.daily-word-zh{font-size:1.5rem;font-weight:700}.daily-word-lo{font-size:1.3rem}.daily-word-play{background:#fff3;border:none;border-radius:50%;width:36px;height:36px;font-size:1rem;cursor:pointer}.business-trip-selector{padding:.75rem;background:#f8f9fa}.scene-tabs{display:flex;gap:.5rem;overflow-x:auto;padding-bottom:.5rem}.scene-tab{padding:.5rem .8rem;border:1px solid #e0e0e0;border-radius:20px;background:#fff;font-size:.75rem;white-space:nowrap;cursor:pointer}.scene-tab.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:transparent}.business-trip-list{padding:.75rem}.business-trip-list .phrase-card{display:flex;align-items:center;justify-content:space-between;padding:.9rem;margin-bottom:.6rem;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000f;cursor:pointer;transition:transform .15s}.business-trip-list .phrase-card:active{transform:scale(.98)}.business-trip-list .phrase-zh{font-size:.95rem;font-weight:500;color:#333}.business-trip-list .phrase-lo{font-size:.9rem;color:#667eea;flex:1;text-align:center;margin:0 .5rem}.business-trip-list .phrase-play{width:32px;height:32px;border-radius:50%;background:#f0f0f0;border:none;font-size:.9rem;cursor:pointer}.quiz-start,.quiz-result{display:flex;flex-direction:column;align-items:center;text-align:center;padding:28px 20px 20px}.quiz-start h2,.quiz-result h2{font-size:24px;margin-bottom:12px;margin-top:8px}.quiz-icon{font-size:64px;margin-bottom:16px}.result-emoji{font-size:72px;margin-bottom:20px;animation:bounce .5s ease}.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{margin:16px 0;display:flex;align-items:center;gap:10px;justify-content:center}.quiz-count-selector select{padding:8px 16px;font-size:16px;border-radius:8px;border:1px solid var(--border);background:var(--surface);color:var(--text)}.start-btn{background:var(--primary);color:#fff;border:none;padding:14px 40px;border-radius:var(--radius);font-size:18px;cursor:pointer}.result-stats{display:flex;gap:32px;margin:24px 0}.stat{display:flex;flex-direction:column;align-items:center}.stat-num{font-size:36px;font-weight:700;color:var(--primary)}.stat-label{font-size:14px;color:var(--text-muted);margin-top:16px;display:flex;flex-direction:column;align-items:center;gap:4px}.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{margin-top:20px;text-align:left;width:100%;max-width:400px}.wrong-list{margin-top:12px}.wrong-item{background:var(--hot-bg);border:1px solid var(--hot-border);padding:12px;border-radius:var(--radius-sm);margin-bottom:8px}.wrong-q{font-weight:700;margin-bottom:4px}.wrong-a{color:var(--success);font-size:14px}.restart-btn{background:var(--primary);color:#fff;border:none;padding:14px 32px;border-radius:var(--radius);font-size:16px;cursor:pointer;margin-top:20px}.quiz-container{padding:16px}.quiz-header{margin-bottom:24px}.quiz-progress-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.quiz-progress-bar{height:6px;background:var(--border);border-radius:3px;overflow:hidden}.quiz-progress-fill{height:100%;background:var(--primary);border-radius:3px;transition:width .3s ease}.quiz-progress{font-size:14px;color:var(--text-muted)}.quiz-score{font-weight:700;color:var(--primary)}.quiz-question{text-align:center;margin-bottom:24px}.quiz-question h3{font-size:28px;margin-bottom:8px}.quiz-question p{color:var(--text-muted)}.play-main-btn{background:var(--primary);color:#fff;border:none;padding:16px 32px;border-radius:var(--radius);font-size:18px;margin:16px 0;cursor:pointer}.play-main-btn:hover{opacity:.9}.opt-zh{font-size:16px;font-weight:500;color:var(--text)}.quiz-options{display:grid;grid-template-columns:1fr 1fr;gap:12px}.quiz-option{background:var(--surface);border:2px solid var(--border);border-radius:var(--radius);padding:12px 10px;font-size:16px;cursor:pointer;transition:all .2s;min-height:70px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px}.quiz-option:hover:not(:disabled){border-color:var(--primary);background:var(--primary-soft)}.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{font-size:16px;font-weight:600;color:var(--primary)}.opt-roman{font-size:12px;color:var(--text-secondary)}.opt-en{font-size:11px;color:var(--text-muted)}.next-btn{width:100%;background:var(--primary);color:#fff;border:none;padding:16px;border-radius:var(--radius);font-size:16px;margin-top:20px;cursor:pointer}.flashcard-start{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;text-align:center;padding:20px}.flashcard-icon{font-size:64px;margin-bottom:24px}.card-info{color:var(--text-muted);margin-bottom:20px}.flashcard-container{padding:16px;display:flex;flex-direction:column;align-items:center}.flashcard-header{width:100%;display:flex;justify-content:space-between;margin-bottom:24px}.card-progress{font-size:14px;color:var(--text-muted)}.card-known{font-weight:700;color:var(--success)}.flashcard{width:100%;max-width:340px;height:220px;perspective:1000px;cursor:pointer;margin-bottom:24px}.flashcard-front,.flashcard-back{position:absolute;width:100%;height:100%;backface-visibility:hidden;display:flex;align-items:center;justify-content:center;border-radius:var(--radius);box-shadow:var(--shadow-lg)}.flashcard-front{background:var(--surface)}.flashcard-back{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);transform:rotateY(180deg);color:#fff}.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{font-size:12px;color:var(--text-muted);margin-top:16px}.card-lo{font-size:28px;font-weight:700}.card-roman{font-size:14px;color:var(--text-secondary);margin-top:6px}.card-en{font-size:16px;margin-top:8px;opacity:.8}.flashcard-actions{display:flex;gap:16px;width:100%;max-width:340px}.know-btn,.unknown-btn{flex:1;padding:14px;border:none;border-radius:var(--radius);font-size:16px;cursor:pointer}.know-btn{background:var(--success);color:#fff}.unknown-btn{background:var(--danger);color:#fff}.flip-hint{color:var(--text-muted);font-size:12px;margin-top:12px}.flashcard-result{padding:28px 20px 20px;text-align:center}.flashcard-result h2{margin-bottom:16px;margin-top:8px}.unknown-review{margin-top:24px;text-align:left}.unknown-list{margin-top:12px}.unknown-item{display:flex;justify-content:space-between;padding:10px 12px;background:var(--hot-bg);border-radius:var(--radius-sm);margin-bottom:8px}.unknown-zh{font-weight:700}.unknown-lo{color:var(--primary)}.quiz-hint{color:var(--text-muted);font-size:14px;margin-bottom:16px;text-align:center}.result-section{margin-top:16px}.correct-answer-hint{text-align:center;padding:12px;background:#34c7591a;border-radius:var(--radius-sm);margin-bottom:12px}.flashcard{cursor:pointer;-webkit-user-select:none;user-select:none}.result-actions{display:flex;flex-direction:column;gap:12px;margin-top:20px;width:100%;max-width:300px}.result-actions button{width:100%}.clear-wrong-btn{background:var(--text-muted);color:#fff;border:none;padding:10px 20px;border-radius:var(--radius);font-size:14px;cursor:pointer;margin-top:8px}.toggle-all-btn{background:var(--surface);border:2px solid var(--border);color:var(--text);padding:10px 20px;border-radius:var(--radius);font-size:14px;cursor:pointer;margin:16px 0;width:100%;max-width:300px}.toggle-all-btn:hover{border-color:var(--primary);background:var(--primary-soft)}.result-tabs{display:flex;gap:8px;margin:16px 0}.result-tab{flex:1;padding:10px 16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);font-size:14px;cursor:pointer;color:var(--text-secondary)}.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);padding:16px;margin-bottom:16px;text-align:center}.saved-progress p{margin:0 0 8px;font-weight:600}.progress-info{font-size:13px;color:var(--text-secondary);font-weight:400!important}.resume-btn{background:var(--primary);color:#fff;border:none;padding:10px 20px;border-radius:var(--radius);font-size:14px;cursor:pointer;margin-right:8px}.result-list{width:100%;max-width:400px;max-height:400px;overflow-y:auto;margin:12px 0}.result-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:12px;margin-bottom:10px;text-align:left}.result-item.correct{border-left:4px solid var(--success)}.result-item.wrong{border-left:4px solid var(--danger)}.result-item-header{display:flex;justify-content:space-between;margin-bottom:8px}.result-item-num{font-size:12px;color:var(--text-muted)}.result-item-status{font-size:16px}.result-item-q{font-size:15px;font-weight:600;margin-bottom:6px}.result-item-correct{font-size:13px;color:var(--success)}.result-item-roman{font-size:12px;color:var(--text-secondary);margin-top:4px}.result-item-wrong{font-size:13px;color:var(--danger);margin-top:4px}.result-item-actions{margin-top:8px}.play-btn{background:var(--primary-soft);border:none;color:var(--primary);padding:6px 12px;border-radius:6px;font-size:12px;cursor:pointer;margin-top:8px}.play-btn:hover{background:var(--primary);color:#fff}.no-wrong{text-align:center;padding:30px;color:var(--success);font-size:16px}.clear-wrong-btn:hover{background:var(--danger)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.feedback-modal{background:var(--card-bg, #1a1a2e);border-radius:16px;padding:24px;max-width:400px;width:100%;max-height:85vh;overflow-y:auto;position:relative;box-shadow:0 20px 60px #0006}.modal-close{position:absolute;top:12px;right:12px;background:none;border:none;font-size:24px;cursor:pointer;color:var(--text-secondary, #888);width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;line-height:1}.modal-close:hover{background:var(--border, #333)}.feedback-modal h2{margin:0 0 4px;font-size:20px;color:var(--text, #fff)}.feedback-desc{color:var(--text-secondary, #888);font-size:14px;margin:0 0 20px}.feedback-type label,.feedback-field label{display:block;font-size:13px;color:var(--text-secondary, #888);margin-bottom:8px}.type-pills{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.type-pill{padding:6px 14px;border-radius:20px;border:1px solid var(--border, #444);background:transparent;color:var(--text, #fff);font-size:13px;cursor:pointer;transition:all .2s}.type-pill.active{background:#4a90d9;border-color:#4a90d9;color:#fff}.type-pill:hover:not(.active){border-color:#4a90d9}.feedback-field{margin-bottom:16px}.feedback-field textarea{width:100%;padding:12px;border:1px solid var(--border, #444);border-radius:10px;background:var(--input-bg, #252540);color:var(--text, #fff);font-size:14px;resize:vertical;font-family:inherit;box-sizing:border-box}.feedback-field textarea:focus{outline:none;border-color:#4a90d9}.feedback-field input{width:100%;padding:12px;border:1px solid var(--border, #444);border-radius:10px;background:var(--input-bg, #252540);color:var(--text, #fff);font-size:14px;box-sizing:border-box}.feedback-field input:focus{outline:none;border-color:#4a90d9}.feedback-submit{width:100%;padding:14px;background:#4a90d9;color:#fff;border:none;border-radius:10px;font-size:16px;font-weight:600;cursor:pointer;transition:background .2s;margin-top:8px}.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{font-size:48px;margin-bottom:16px}.feedback-success h3{margin:0 0 8px;color:var(--text, #fff)}.feedback-success p{color:var(--text-secondary, #888);margin:0}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.tab-content{animation:fadeIn .3s ease-out}.nav-item.active{transform:scale(1.1);transition:transform .2s ease}.translate-section{max-height:0;overflow:hidden;transition:max-height .3s ease-out,padding .3s ease-out;padding:0 12px;background:var(--surface);border-bottom:1px solid var(--border)}.translate-section.expanded{max-height:500px;padding:12px}.full-page{flex:1;overflow-y:auto;padding-bottom:70px}.hot-header,.fav-header,.official-header{padding:12px 16px;background:var(--surface);border-bottom:1px solid var(--border)}.hot-title,.fav-title,.official-title{font-size:16px;font-weight:600}.tab-content{flex:1;overflow-y:auto;padding-bottom:70px;min-height:calc(100vh - 120px)}.page{padding:0 var(--page-gutter);padding-bottom:80px;min-height:calc(100vh - 120px)}.translate-page .trans-wrap{padding:1rem 0}.settings-page{padding:0 1rem 80px}.settings-section{background:var(--surface);border-radius:16px;padding:1rem;margin-bottom:.75rem;box-shadow:var(--shadow)}.settings-section-title{font-size:.8rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.75rem}.settings-row{display:flex;gap:8px;flex-wrap:wrap}.settings-lang-btn{padding:6px 14px;border-radius:20px;border:1.5px solid var(--border);background:var(--bg);color:var(--text);font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s}.settings-lang-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.settings-toggle-row{display:flex;align-items:center;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--border-light)}.settings-toggle-row:last-child{border-bottom:none}.toggle-btn{padding:4px 14px;border-radius:12px;border:none;background:var(--bg-secondary);color:var(--text-secondary);font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s}.toggle-btn.on{background:var(--primary);color:#fff}.settings-btn{width:100%;padding:12px;border-radius:12px;border:none;font-size:.95rem;font-weight:600;cursor:pointer;margin-top:8px;display:block;text-align:center}.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{font-size:.85rem;color:var(--text-secondary);margin-bottom:8px}.settings-about{text-align:center;color:var(--text-secondary);font-size:.85rem}.settings-about p{margin:4px 0}.pack-selector{display:flex;gap:6px;padding:0 1rem .5rem;overflow-x:auto;scrollbar-width:none}.pack-sel-btn{flex-shrink:0;padding:6px 12px;border-radius:16px;border:1.5px solid var(--border);background:var(--surface);color:var(--text-secondary);font-size:.8rem;cursor:pointer;white-space:nowrap}.pack-sel-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.browse-packs{padding:0 1rem 2rem}.browse-section-title{font-size:.8rem;font-weight:600;color:var(--text-secondary);padding:.5rem 0 .3rem;text-transform:uppercase;letter-spacing:.05em}.browse-pack-list{display:flex;flex-direction:column;gap:.5rem}.browse-pack-card{display:flex;align-items:center;justify-content:space-between;padding:.85rem 1rem;background:var(--surface);border-radius:12px;border:1px solid var(--border);cursor:pointer;transition:all .15s}.browse-pack-card:active{transform:scale(.98);opacity:.8}.browse-pack-name{font-weight:600;font-size:1rem}.browse-pack-meta{font-size:.8rem;color:var(--text-secondary);margin-top:2px}.browse-pack-arrow{font-size:1.5rem;color:var(--text-muted)}.browse-pack-detail{display:flex;flex-direction:column;gap:.5rem}.browse-detail-header{display:flex;align-items:center;gap:.5rem;padding:.3rem 0}.browse-detail-title{flex:1;font-weight:700;font-size:1rem}.browse-learn-btn{padding:6px 14px;background:var(--primary);color:#fff;border:none;border-radius:20px;font-size:.85rem;cursor:pointer}.browse-search{width:100%;padding:10px 14px;border-radius:10px;border:1.5px solid var(--border);background:var(--surface);color:var(--text);font-size:.95rem;outline:none;box-sizing:border-box}.browse-search:focus{border-color:var(--primary)}.browse-word-list{display:flex;flex-direction:column;gap:1px;max-height:60vh;overflow-y:auto}.browse-word-row{display:flex;align-items:center;gap:.8rem;padding:.5rem;border-bottom:1px solid var(--border)}.browse-word-lo{flex:1;font-size:1rem;font-weight:500}.browse-word-zh{flex:1;font-size:.95rem;color:var(--text-secondary)}.browse-word-en{font-size:.8rem;color:var(--text-muted)}.learn-tabs{display:flex;gap:6px;padding:.75rem 1rem;overflow-x:auto;scrollbar-width:none}.learn-tabs::-webkit-scrollbar{display:none}.learn-tab-btn{flex-shrink:0;padding:8px 16px;border-radius:20px;border:none;background:var(--surface);color:var(--text-secondary);font-size:.85rem;font-weight:700;cursor:pointer;box-shadow:var(--shadow);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{display:flex;gap:8px;padding:.5rem 0}.fav-sort-btn{padding:5px 14px;border-radius:16px;border:1.5px solid var(--border);background:transparent;color:var(--text-secondary);font-size:.8rem;font-weight:600;cursor:pointer}.fav-sort-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.fav-group-title{font-size:.75rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;padding:1rem 0 .25rem}.trans-history{margin-top:1rem}.trans-history-title{font-size:.8rem;font-weight:700;color:var(--text-secondary);margin-bottom:.5rem}.trans-history-item{display:flex;gap:8px;padding:8px 0;border-bottom:1px solid var(--border-light);cursor:pointer;font-size:.85rem}.trans-history-item:hover{background:var(--surface-hover)}.trans-history-from{flex:1;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.trans-history-arrow{color:var(--text-muted);flex-shrink:0}.trans-history-to{flex:1;color:var(--primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@keyframes pageSlideIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.page,.page.translate-page,.page.settings-page{animation:pageSlideIn .2s ease-out}.nav-item.active{color:var(--primary)}:root{--page-bg-layer-1: #f7f8ff;--page-bg-layer-2: #eef1ff;--page-bg-layer-3: #f5f2ff;--glass-border: rgba(255, 255, 255, .55);--glass-highlight: rgba(255, 255, 255, .82);--nav-grad-start: rgba(255, 255, 255, .92);--nav-grad-end: rgba(244, 246, 255, .88)}[data-theme=dark]{--page-bg-layer-1: #0d1025;--page-bg-layer-2: #131935;--page-bg-layer-3: #15112d;--glass-border: rgba(132, 146, 255, .16);--glass-highlight: rgba(255, 255, 255, .08);--nav-grad-start: rgba(20, 24, 44, .94);--nav-grad-end: rgba(26, 30, 58, .9)}body{background:radial-gradient(circle at top center,rgba(126,108,255,.14),transparent 36%),radial-gradient(circle at 100% 10%,rgba(0,122,255,.12),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,#488afff5 55%,#7e58d6fa),linear-gradient(180deg,#ffffff29,#fff0);box-shadow:0 18px 40px #4e5fd63d,0 3px 10px #232b5d29,inset 0 1px #ffffff42;border:1px solid rgba(255,255,255,.1);overflow:hidden}.hdr:before{content:"";position:absolute;inset:0 0 auto;height:55%;background:linear-gradient(180deg,#ffffff38,#fff0);pointer-events:none}.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{left:50%;right:auto;width:min(100%,520px);transform:translate(-50%);margin:0 auto;background:linear-gradient(180deg,var(--nav-grad-start),var(--nav-grad-end));border:1px solid rgba(124,137,255,.12);border-top-color:#ffffff73;border-radius:22px 22px 0 0;box-shadow:0 -4px #ffffff61 inset,0 -20px 40px #20295b1f,0 -6px 16px #7b5bff1a;overflow:hidden}.bottom-nav:before{content:"";position:absolute;top:0;left:10px;right:10px;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.88),transparent);pointer-events:none}.nav-item{gap:.34rem;padding:.6rem .35rem calc(.78rem + env(safe-area-inset-bottom,0px));min-height:66px;font-size:11px;font-weight:700;letter-spacing:.01em}.nav-item svg{width:21px;height:21px;transition:transform .22s ease,color .22s ease,filter .22s ease}.nav-item span{line-height:1}.nav-item.active{color:#4a63ff;transform:translateY(-2px)}.nav-item.active svg{color:#4a63ff;transform:translateY(-1px) scale(1.05);filter:drop-shadow(0 6px 10px rgba(74,99,255,.24))}.nav-item.active:before{content:"";position:absolute;top:7px;right:10px;bottom:10px;left:10px;border-radius:18px;background:linear-gradient(180deg,#657fff2e,#7a59ff1a);box-shadow:inset 0 1px #ffffffb3,0 8px 20px #606dff1f;border:1px solid rgba(113,121,255,.16);z-index:-1}.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:#7a88ff2e;border-top-color:#ffffff14;box-shadow:0 -2px #ffffff0d inset,0 -24px 40px #00000059,0 -8px 18px #3043a233}[data-theme=dark] .nav-item.active{color:#a9b8ff}[data-theme=dark] .nav-item.active:before{background:linear-gradient(180deg,#6976ff38,#5b49bf2e);border-color:#8391ff3d;box-shadow:inset 0 1px #ffffff14,0 10px 20px #27306259}.cats-scroll{gap:.7rem;padding:.8rem var(--page-gutter) .65rem}.cat-pill{min-height:44px;padding:.68rem 1rem;border-radius:999px;border:1px solid rgba(110,124,255,.14);background:linear-gradient(180deg,#fffffff5,#f6f8ffeb);box-shadow:0 8px 18px #717fff14,inset 0 1px #ffffffdb;color:var(--text-secondary);font-size:.8rem;font-weight:700}.cat-pill.active{background:linear-gradient(135deg,#6a7cff,#4b90ff,#7a5dff);color:#fff;border-color:#ffffff2e;box-shadow:0 10px 22px #5d73ff40,inset 0 1px #ffffff38}[data-theme=dark] .cat-pill{background:linear-gradient(180deg,#1c2241eb,#181c36f5);border-color:#7783ff33;box-shadow:0 10px 20px #0003,inset 0 1px #ffffff0d}.phrase-list{gap:1rem;padding-top:.35rem}.phrase-card{position:relative;overflow:hidden;padding:1.05rem 1rem 1rem;border-radius:22px;background:linear-gradient(180deg,#fffffffa,#f8fafff7),linear-gradient(135deg,#6c77ff0d,#50acff08);border:1px solid rgba(111,126,255,.12);box-shadow:0 14px 30px #535fb414,0 4px 12px #0f172a0a,inset 0 1px #ffffffe6;transition:transform .22s ease,box-shadow .22s ease,border-color .22s ease,background .22s ease}.phrase-card:before{content:"";position:absolute;inset:0 0 auto;height:54px;background:linear-gradient(180deg,#7e89ff14,#fff0);pointer-events:none}[data-theme=dark] .phrase-card{background:linear-gradient(180deg,#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{transform:translateY(-2px);box-shadow:0 18px 34px #5560be1f,0 6px 16px #0f172a14,inset 0 1px #ffffffe6;border-color:#657aff33}.phrase-card:active{transform:translateY(0) scale(.986);background:linear-gradient(180deg,#f5f8fffa,#eff4fff5);box-shadow:0 10px 20px #515fb61f}.card-lao-row{align-items:flex-start;gap:.7rem;margin-bottom:.85rem}.card-lao{font-size:1.38rem;line-height:1.28;letter-spacing:.01em}.card-roman{margin-top:-.15rem;margin-bottom:.45rem;font-size:.88rem;line-height:1.5;opacity:.88}.card-trans{gap:.48rem;margin-bottom:.65rem}.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{border-radius:999px;padding:.32rem .72rem;background:linear-gradient(180deg,#ecf0fff2,#e5eaf9eb)}.card-play-btn{background:linear-gradient(135deg,#617dff,#3e97ff);box-shadow:0 10px 18px #4577ff47,inset 0 1px #ffffff3d}.card-fav-btn{background:linear-gradient(180deg,#f3f5fcfa,#e8ecf7f0);box-shadow:inset 0 1px #fffc}.quick-translate-card{position:relative;margin:.9rem var(--page-gutter) 1rem;padding:1.05rem;border-radius:24px;background:linear-gradient(135deg,#647efffa,#5895fff2 55%,#7857d6fa);border:1px solid rgba(255,255,255,.16);box-shadow:0 20px 34px #5462ce38,inset 0 1px #ffffff3d;overflow:hidden}.quick-translate-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,#ffffff29,#fff0);pointer-events:none}.quick-translate-title{position:relative;font-size:.95rem;font-weight:800;margin-bottom:.9rem;letter-spacing:.01em}.quick-translate-input-row{position:relative;gap:.65rem;align-items:stretch}.quick-translate-input{min-height:48px;border:1px solid rgba(255,255,255,.25);border-radius:15px;background:#fffffff5;box-shadow:inset 0 1px #fffffff2,0 8px 18px #202d7314;color:#1f2955;font-size:.95rem;font-weight:500;outline:none;transition:box-shadow .2s ease,transform .2s ease}.quick-translate-input:focus{box-shadow:0 0 0 4px #fff3,0 10px 20px #202d7324}.quick-translate-btn{min-width:84px;min-height:48px;border-radius:15px;background:linear-gradient(135deg,#fff,#eef3ff);color:#5468ff;font-weight:800;letter-spacing:.01em;box-shadow:0 10px 18px #232d6c24,inset 0 1px #fffffff2;transition:transform .18s ease,box-shadow .18s ease,opacity .18s ease}.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{position:relative;margin-top:.9rem;padding:.9rem .95rem;border-radius:16px;border:1px solid rgba(255,255,255,.15);background:#ffffff24;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.lo-text{font-size:1.14rem;font-weight:700;line-height:1.35}.copy-btn{width:40px;height:40px;border-radius:12px;background:#ffffff26}.learn-tabs{gap:.7rem;padding:.8rem 0 1rem}.learn-tab-btn{min-height:44px;padding:.72rem 1.05rem;border-radius:999px;background:linear-gradient(180deg,#fffffffa,#f5f7fff2);border:1px solid rgba(108,122,255,.1);box-shadow:0 8px 18px #505bb812,inset 0 1px #fffffff2}.learn-tab-btn.active{background:linear-gradient(135deg,var(--accent) 0%,var(--accent-dark) 100%);box-shadow:0 12px 22px #5465e83d,inset 0 1px #ffffff29}.quiz-start,.quiz-result,.flashcard-start,.flashcard-result,.quiz-container,.flashcard-container{background:linear-gradient(180deg,#ffffffd6,#f8faffdb);border:1px solid rgba(108,122,255,.1);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(180deg,#181d38eb,#14182ef0);border-color:#7684ff29;box-shadow:0 20px 36px #0000003d,inset 0 1px #ffffff0d}.quiz-start,.quiz-result,.flashcard-start,.flashcard-result{padding:1.5rem 1rem;min-height:62vh}.quiz-container,.flashcard-container{padding:1rem}.quiz-progress-bar{height:8px;background:#6b7aff1f;border-radius:999px}.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{min-height:76px;padding:.95rem .75rem;background:linear-gradient(180deg,#fffffffa,#f6f8fff5);border:1px solid rgba(111,126,255,.12);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(180deg,#fffffffa,#f7f9fff5);box-shadow:0 10px 20px #4a56b60f}.flashcard{position:relative;max-width:100%;height:240px}.flashcard-front,.flashcard-back{border:1px solid rgba(110,124,255,.14);box-shadow:0 20px 40px #525fb829,inset 0 1px #ffffffbf}.flashcard-front{background:linear-gradient(180deg,#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 (max-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 (max-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 (max-width: 360px){.bottom-nav{width:calc(100% - 6px);border-radius:18px 18px 0 0}.nav-item{gap:.28rem;font-size:10px}.nav-item svg{width:20px;height:20px}.phrase-card{padding:.95rem .85rem;border-radius:20px}.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{background:#ffffffdb;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}[data-theme=dark] .trans-wrap,[data-theme=dark] .settings-wrap{background:#181c2ed6}.translate-page .trans-wrap{width:100%;margin:.35rem 0 .5rem;padding:.95rem;border-radius:24px;box-shadow:0 18px 34px #505ebe1f,0 4px 12px #0f172a0d,inset 0 1px #ffffffb3}.translate-page .trans-header{margin-bottom:.9rem}.trans-title{font-size:.9rem;letter-spacing:.1em}.trans-history-toggle,.trans-arrow-btn{border:1px solid rgba(102,126,234,.14);background:linear-gradient(180deg,#fffffff2,#f1f5ffeb);color:var(--primary);box-shadow:0 8px 18px #606dff1a,inset 0 1px #ffffffe6}.trans-history-toggle{width:42px;height:42px;border-radius:14px;cursor:pointer;font-size:1rem}.trans-row{gap:.7rem;margin-bottom:.8rem}.trans-lang-select{min-height:48px;padding:.75rem 2.3rem .75rem .9rem;border-radius:14px;border:1.5px solid rgba(102,126,234,.16);background:linear-gradient(180deg,#fffffff5,#f4f7ffeb);font-size:1rem;font-weight:700;line-height:1.2;box-shadow:inset 0 1px #fffffff2;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-size:6px 6px,6px 6px,100% 100%;background-repeat:no-repeat}.trans-lang-select:focus,.trans-input:focus{border-color:#4a63ffb3;box-shadow:0 0 0 4px #4a63ff1f}.trans-arrow-btn{width:48px;min-width:48px;height:48px;border-radius:14px;cursor:pointer;font-size:1.2rem}.trans-input{min-height:124px;padding:.95rem 1rem;border-radius:18px;border:1.5px solid rgba(102,126,234,.16);background:linear-gradient(180deg,#fffffffa,#f7f9fff0);font-size:1.1rem!important;font-weight:500;line-height:1.75;margin-bottom:.8rem;box-shadow:inset 0 1px #fffffff2}.trans-input::placeholder{font-size:1rem}.trans-submit-btn{min-height:54px;padding:.95rem 1.2rem;border-radius:18px;background:linear-gradient(135deg,#5d7cff,#3f96ff 55%,#7660ff);font-size:1.08rem;font-weight:800;letter-spacing:.01em;box-shadow:0 16px 28px #4a6eff47,inset 0 1px #ffffff47}.trans-submit-btn:active{background:linear-gradient(135deg,#4768f6,#2f84eb 55%,#654df4)}.trans-result-box{margin-top:.9rem;padding:1rem 1.05rem;border-radius:20px;background:linear-gradient(180deg,#fffffff0,#f4f7ffe6);border:1px solid rgba(102,126,234,.12);box-shadow:0 12px 24px #4a56b614}.trans-result,.trans-result-lo{font-size:1.35rem;line-height:1.65}.trans-result-actions{gap:.65rem;flex-wrap:wrap}.trans-play-btn,.trans-action-btn{min-height:46px;padding:0 1rem;border-radius:14px;font-size:.92rem;font-weight:700}.trans-history{margin-top:1rem;padding-top:.9rem}.trans-history-title{font-size:.82rem;margin-bottom:.7rem}.trans-history-item{padding:.75rem .8rem;margin-bottom:.45rem;border-radius:14px;border:1px solid rgba(102,126,234,.08);font-size:.98rem}.trans-history-from,.trans-history-to{font-size:.98rem;line-height:1.45}.trans-history-arrow{font-size:.9rem}.mic-btn{width:52px;height:52px;border-radius:16px;display:inline-flex;align-items:center;justify-content:center;font-size:1.15rem;box-shadow:0 12px 24px #4a63ff2e}@media (max-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{margin-top:.2rem;padding:.85rem;border-radius:20px}.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, rgba(107,125,255,.14), rgba(61,155,255,.08) 45%, rgba(139,92,255,.06) 100%);--surface-strong: rgba(255,255,255,.92);--surface-soft: rgba(248,250,255,.9);--line-strong: rgba(107,125,255,.16)}[data-theme=dark]{--surface-strong: rgba(20,24,46,.9);--surface-soft: rgba(26,31,58,.88);--line-strong: rgba(145,156,255,.18)}.page.translate-page{padding-left:0;padding-right:0;padding-top:.35rem;padding-bottom:calc(92px + env(safe-area-inset-bottom,0px))}.translate-page .trans-wrap{width:100%;margin:0;padding:.75rem .9rem .9rem;border-radius:0;border:none;background:transparent;box-shadow:none;backdrop-filter:none;-webkit-backdrop-filter:none}.translate-page .trans-wrap:before{content:"";display:block;height:0}.translate-page .trans-header{margin-bottom:.9rem;padding:0 .1rem}.translate-page .trans-title{font-size:1.15rem;font-weight:900;letter-spacing:.02em;color:var(--text);text-transform:none}.trans-history-toggle{width:48px;height:48px;border-radius:16px;border:1px solid var(--line-strong);background:var(--surface-strong);color:var(--primary);font-size:1.08rem;font-weight:700;box-shadow:0 14px 28px #4d60c41f}.translate-page .trans-row:first-of-type{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.7rem!important;margin-bottom:.9rem!important}.translate-page .trans-row:first-of-type button{min-height:52px;padding:.9rem .7rem!important;border:1px solid rgba(255,255,255,.18)!important;border-radius:18px!important;background:var(--surface-strong)!important;color:var(--text)!important;font-size:1.02rem!important;font-weight:800!important;letter-spacing:.01em;box-shadow:0 12px 24px #4e59ae14,inset 0 1px #ffffffc7}.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{min-height:56px;padding:.9rem 2.5rem .9rem 1rem;border-radius:18px;border:1px solid var(--line-strong);background-color:var(--surface-strong);font-size:1.05rem;font-weight:800;color:var(--text);box-shadow:0 10px 24px #3d4fae14}.trans-arrow-btn{width:56px;min-width:56px;height:56px;border:none;border-radius:18px;background:var(--hero-grad);color:#fff;font-size:1.35rem;font-weight:900;box-shadow:0 18px 30px #466dff3d}.trans-input{min-height:180px;padding:1.2rem 1.1rem;border:1px solid rgba(110,126,255,.14);border-radius:24px;background:linear-gradient(180deg,#fffffff5,#f7f9ffeb),var(--hero-grad-soft);color:var(--text);font-size:1.14rem!important;font-weight:600;line-height:1.75;box-shadow:0 20px 40px #4e5cb61f,inset 0 1px #ffffffeb}.trans-input::placeholder{color:var(--text-secondary);opacity:.7;font-size:1rem}.trans-submit-btn{min-height:58px;border-radius:20px;background:var(--hero-grad);font-size:1.12rem;font-weight:900;letter-spacing:.02em;box-shadow:0 22px 34px #4168ff47,inset 0 1px #ffffff42}.trans-result-box{margin-top:1rem;padding:.4rem 0 0;background:transparent;border:none;border-radius:0;box-shadow:none}.trans-result-lo{margin-bottom:.9rem;font-size:1.6rem;font-weight:900;line-height:1.72;color:var(--text);word-break:break-word}.trans-result-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.8rem}.trans-play-btn,.trans-action-btn{min-height:56px;padding:0 1rem;border:none;border-radius:18px;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{margin-top:.9rem;padding-top:0;border-top:none;background:transparent}.trans-history-title{display:inline-flex;align-items:center;gap:.4rem;margin-bottom:.75rem;padding:.4rem .8rem;border-radius:999px;background:#6b7dff1a;color:var(--primary);font-size:.82rem;font-weight:800}.trans-history-item{align-items:center;gap:.55rem;margin-bottom:.55rem;padding:.9rem .95rem;border:1px solid var(--line-strong);border-radius:18px;background:var(--surface-soft);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{font-weight:800;color:var(--text)}.bottom-nav{width:calc(100% - 12px);bottom:6px;border:1px solid rgba(255,255,255,.35);border-radius:24px;background:linear-gradient(180deg,#fffffff0,#f4f7ffeb),linear-gradient(135deg,#6a7cff14,#419aff0a);box-shadow:0 24px 44px #252f602e,0 8px 18px #6271ff1a,inset 0 1px #ffffffbf;backdrop-filter:blur(22px) saturate(160%);-webkit-backdrop-filter:blur(22px) saturate(160%)}.bottom-nav:after{content:"";position:absolute;top:10px;bottom:10px;width:1px;left:25%;background:linear-gradient(180deg,transparent,rgba(120,134,255,.16),transparent);box-shadow:25vw 0 #7886ff29,50vw 0 #7886ff29;pointer-events:none}.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{top:7px;right:10px;bottom:12px;left:10px;border-radius:18px;background:linear-gradient(180deg,#5f76ff33,#7b59ff24)}.nav-item.active:after{width:28px;height:4px;border-radius:999px}.cats-scroll{gap:.75rem;padding-top:.95rem;padding-bottom:.85rem}.cat-pill{min-height:46px;padding:.76rem 1.05rem;border:1px solid var(--line-strong);border-radius:999px;background:var(--surface-strong);font-size:.88rem;font-weight:800;color:var(--text-secondary);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{padding:1.15rem 1.05rem 1rem;border-radius:24px;border:1px solid var(--line-strong);background:linear-gradient(180deg,#fffffffa,#f6f8fff5),linear-gradient(135deg,#677cff0f,#4799ff08);box-shadow:0 18px 34px #4d5cb21a,inset 0 1px #ffffffd6}.card-lao-row{gap:.8rem;margin-bottom:.95rem}.card-lao{font-size:1.42rem;font-weight:900;color:var(--text)}.card-roman{font-size:.92rem;line-height:1.55;margin-bottom:.55rem}.card-trans{gap:.55rem;margin-bottom:.75rem}.trans-lang-label{padding:.28rem .5rem;border-radius:999px;font-size:.68rem}.trans-text{font-size:1rem;line-height:1.62;color:var(--text)}.card-actions{gap:.6rem}.card-play-btn,.card-fav-btn,.play-btn,.fav-btn{width:52px;height:52px;border-radius:18px}.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{background:linear-gradient(135deg,#ff6a93,#ff4d7a);color:#fff;border-color:transparent}.card-category{margin-top:.35rem;padding:.38rem .8rem;border-radius:999px;font-size:.76rem;font-weight:700}.learn-page .learn-content,.quiz-start,.quiz-result,.flashcard-start,.flashcard-result,.quiz-container,.flashcard-container{border-radius:26px;border:1px solid var(--line-strong);background:linear-gradient(180deg,#fffffff2,#f7f9ffeb);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{min-height:46px;padding:.8rem 1.15rem;border-radius:999px;background:var(--surface-strong);border:1px solid var(--line-strong);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{min-height:82px;border-radius:20px;border:1px solid var(--line-strong);background:var(--surface-strong)}.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{min-height:52px;border-radius:18px;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{background:linear-gradient(180deg,#181d38f5,#12172cf0);color:var(--text);border-color:#8895ff29;box-shadow:0 18px 32px #0000003d,inset 0 1px #ffffff0a}[data-theme=dark] .trans-result-box{background:transparent;box-shadow:none}[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(180deg,#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(180deg,#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 (max-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 (max-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 (min-width: 768px){:root{--page-gutter: 1.5rem}.app{max-width:min(1120px,calc(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,calc(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 ease,box-shadow .22s ease,border-color .22s ease,background .22s ease,color .22s ease}.phrase-card:hover,.quiz-option:hover:not(:disabled),.result-item:hover,.settings-section:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.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-page{padding:.75rem 1rem calc(100px + env(safe-area-inset-bottom,0px));display:flex;flex-direction:column;gap:1rem}.share-stats-card{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:22px;padding:1.25rem;color:#fff;box-shadow:0 16px 32px #667eea47}.share-stats-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.share-stats-date{font-size:.85rem;font-weight:700;opacity:.9}.share-streak{background:#fff3;padding:.25rem .7rem;border-radius:999px;font-size:.78rem;font-weight:700}.share-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}.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{font-size:.72rem;opacity:.85;margin-top:2px}.share-proverb-card{background:var(--surface);border-radius:22px;padding:1.25rem;text-align:center;box-shadow:var(--shadow-md);border:1px solid var(--border)}.share-proverb-label{font-size:.75rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.75rem}.share-proverb-lo{font-size:1.5rem;font-weight:900;color:var(--primary);margin-bottom:.5rem;cursor:pointer;line-height:1.4;transition:opacity .2s}.share-proverb-lo:hover{opacity:.75}.share-proverb-zh{font-size:1rem;font-weight:600;color:var(--text);margin-bottom:.25rem}.share-proverb-en{font-size:.82rem;color:var(--text-secondary)}.share-actions{display:flex;gap:.75rem}.share-btn{flex:1;padding:.85rem;border-radius:16px;border:1.5px solid var(--border);background:var(--surface);color:var(--text);font-size:.95rem;font-weight:700;cursor:pointer;transition:all .2s;font-family:inherit}.share-btn.primary{background:var(--hero-grad, linear-gradient(135deg, #667eea 0%, #764ba2 100%));color:#fff;border-color:transparent;box-shadow:0 12px 24px #667eea3d}.share-btn:active{transform:scale(.96)}.share-proverbs-list{background:var(--surface);border-radius:22px;padding:1rem;box-shadow:var(--shadow);border:1px solid var(--border)}.share-proverbs-title{font-size:.78rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.85rem}.share-proverb-item{display:flex;gap:.75rem;padding:.6rem .5rem;border-bottom:1px solid var(--border-light);cursor:pointer;transition:background .15s;border-radius:8px}.share-proverb-item:last-child{border-bottom:none}.share-proverb-item:hover{background:var(--surface-hover)}.share-proverb-item-lo{font-size:.9rem;font-weight:700;color:var(--primary);min-width:100px;flex-shrink:0}.share-proverb-item-zh{font-size:.88rem;color:var(--text-secondary)}.announcement-banner{margin:.75rem 0}.announcement-item{background:linear-gradient(135deg,#667eea1f,#764ba21f);border:1px solid rgba(102,126,234,.2);border-radius:12px;padding:.75rem 1rem;margin-bottom:.5rem;font-size:.88rem;color:var(--primary)}.login-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:9999;display:flex;align-items:center;justify-content:center;padding:16px;animation:fadeIn .2s ease}.login-modal{background:var(--card-bg, #1e1e2e);border:1px solid rgba(255,255,255,.1);border-radius:24px;padding:40px 32px 32px;width:100%;max-width:400px;position:relative;box-shadow:0 24px 80px #00000080;animation:slideUp .25s ease}.login-modal-close{position:absolute;top:12px;right:16px;background:none;border:none;color:var(--text-secondary, #888);font-size:24px;cursor:pointer;line-height:1;padding:4px}.login-modal-logo{text-align:center;margin-bottom:16px}.login-modal-logo img{width:64px;height:64px;border-radius:16px;box-shadow:0 4px 20px #4a90d966}.login-modal-title{text-align:center;font-size:24px;font-weight:700;color:var(--text, #fff);margin:0 0 8px}.login-modal-sub{text-align:center;color:var(--text-secondary, #aaa);font-size:14px;margin:0 0 24px}.login-error{background:#e9456026;border:1px solid rgba(233,69,96,.3);color:#e94560;border-radius:10px;padding:10px 14px;font-size:13px;margin-bottom:16px}.login-input{width:100%;box-sizing:border-box;padding:14px 16px;border:1.5px solid rgba(255,255,255,.1);border-radius:12px;background:#ffffff0d;color:var(--text, #fff);font-size:15px;margin-bottom:12px;outline:none;transition:border-color .2s}.login-input:focus{border-color:var(--primary, #4a90d9)}.login-submit-btn{width:100%;padding:14px;background:var(--primary, #4a90d9);color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;margin-top:4px;transition:opacity .2s,transform .1s}.login-submit-btn:active{transform:scale(.98);opacity:.9}.login-divider{display:flex;align-items:center;gap:12px;margin:20px 0;color:var(--text-secondary, #888);font-size:13px}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:#ffffff1a}.login-google-btn{width:100%;padding:13px;background:#ffffff14;border:1.5px solid rgba(255,255,255,.12);border-radius:12px;color:var(--text, #fff);font-size:15px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;transition:background .2s}.login-google-btn:hover{background:#ffffff21}.login-toggle-mode{text-align:center;margin:20px 0 0;font-size:13px;color:var(--text-secondary, #aaa)}.login-toggle-mode span{color:var(--primary, #4a90d9);cursor:pointer;font-weight:600;margin-left:6px}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.share-page{padding:.75rem 1rem calc(100px + env(safe-area-inset-bottom,0px));display:flex;flex-direction:column;gap:.85rem}.share-hero-card{background:linear-gradient(135deg,#667eea,#764ba2 30%,#f093fb 70%,#f5576c);border-radius:28px;padding:2rem 1.75rem;color:#fff;cursor:pointer;box-shadow:0 20px 50px #667eea73,0 0 0 1px #ffffff1a inset;position:relative;overflow:hidden;transition:transform .25s,box-shadow .25s;text-align:center}.share-hero-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,rgba(255,255,255,.15) 0%,transparent 60%);pointer-events:none}.share-hero-card:active{transform:scale(.98);box-shadow:0 10px 24px #667eea59}.share-hero-date{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;opacity:.85;margin-bottom:.85rem}.share-hero-lo{font-size:1.85rem;font-weight:900;line-height:1.35;margin-bottom:.75rem;letter-spacing:.01em}.share-hero-zh{font-size:1.05rem;font-weight:600;opacity:.92;margin-bottom:.6rem}.share-hero-hint{font-size:.72rem;opacity:.55;letter-spacing:.04em}.share-day-tabs{display:flex;gap:.5rem;overflow-x:auto;scrollbar-width:none;padding-bottom:2px}.share-day-tabs::-webkit-scrollbar{display:none}.share-day-tab{flex-shrink:0;display:flex;flex-direction:column;align-items:center;gap:3px;padding:.7rem 1rem;border-radius:16px;border:1.5px solid rgba(255,255,255,.1);background:#ffffff0f;color:#fff9;cursor:pointer;transition:all .25s;box-shadow:none;min-width:60px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.share-day-tab.active{background:linear-gradient(135deg,#667eea80,#764ba280);border-color:#667eea99;color:#fff;box-shadow:0 4px 16px #667eea59;transform:translateY(-2px)}.day-label{font-size:.72rem;font-weight:800;letter-spacing:.04em}.day-date{font-size:.65rem;opacity:.65}.share-stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:.6rem}.share-stat-chip{background:#ffffff1a;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.15);border-radius:18px;padding:1rem .5rem;text-align:center;box-shadow:0 6px 20px #0000002e;display:flex;flex-direction:column;gap:4px;transition:transform .2s}.share-stat-chip:hover{transform:translateY(-2px)}.chip-num{font-size:1.3rem;font-weight:900;background:linear-gradient(135deg,#667eea,#f093fb);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1}.chip-label{font-size:.65rem;color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.04em}.share-actions{display:flex;justify-content:center;padding:.5rem 0}.share-card-btn{width:100%;max-width:340px;margin:0 auto;padding:1rem 2rem;border-radius:50px;border:none;background:linear-gradient(135deg,#667eea,#764ba2,#f093fb);color:#fff;font-size:1.1rem;font-weight:800;cursor:pointer;box-shadow:0 8px 32px #667eea80;transition:all .25s;letter-spacing:.03em;font-family:inherit;position:relative;overflow:hidden}.share-card-btn:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,rgba(255,255,255,.25) 0%,transparent 50%);pointer-events:none}.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{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d1;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:9000;display:flex;align-items:center;justify-content:center;padding:16px;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.share-preview-modal{background:#1a1a2e;border-radius:24px;width:100%;max-width:420px;overflow:hidden;box-shadow:0 24px 60px #00000080;animation:slideUp .25s ease}@keyframes slideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}.share-preview-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;font-size:15px;font-weight:600;color:#fff;border-bottom:1px solid rgba(255,255,255,.08)}.preview-close-btn{background:#ffffff1a;border:none;color:#fff;width:28px;height:28px;border-radius:50%;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center}.preview-close-btn:hover{background:#fff3}.share-preview-image-wrap{padding:16px;display:flex;align-items:center;justify-content:center;min-height:200px}.share-preview-image{width:100%;border-radius:12px;opacity:0;transition:opacity .3s;box-shadow:0 8px 24px #0006}.share-preview-image.loaded{opacity:1}.share-mobile-hint{text-align:center;font-size:13px;color:#ffffff80;padding:0 16px 8px}.share-preview-loading{display:flex;flex-direction:column;align-items:center;gap:12px;color:#ffffff80;font-size:14px}.spinner{width:32px;height:32px;border:3px solid rgba(255,255,255,.15);border-top-color:#4a90d9;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.share-channel-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;padding:0 16px 20px}.share-channel-btn{background:#ffffff12;border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:14px 8px;display:flex;flex-direction:column;align-items:center;gap:6px;cursor:pointer;transition:background .2s,transform .15s;color:#fff}.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-icon{font-size:24px}.channel-name{font-size:12px;opacity:.8}.learn-guide-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:9000;display:flex;align-items:center;justify-content:center;padding:16px}.learn-guide-card{background:var(--card-bg, #1e1e2e);border:1px solid rgba(255,255,255,.1);border-radius:24px;padding:32px 28px 24px;width:100%;max-width:380px;text-align:center;box-shadow:0 24px 80px #00000080;animation:slideUp .25s ease}.learn-guide-icon{font-size:3.5rem;display:block;margin-bottom:12px}.learn-guide-title{font-size:1.35rem;font-weight:800;color:var(--text);display:block;margin-bottom:10px}.learn-guide-desc{font-size:.95rem;color:var(--text-secondary);line-height:1.55;margin:0 0 20px}.learn-guide-dots{display:flex;justify-content:center;gap:8px;margin-bottom:20px}.guide-dot{width:8px;height:8px;border-radius:50%;background:#fff3;transition:all .2s}.guide-dot.active{background:var(--primary);width:24px;border-radius:4px}.learn-guide-actions{display:flex;gap:12px;justify-content:space-between;margin-bottom:12px}.guide-btn{flex:1;padding:12px;border-radius:12px;border:none;font-size:.95rem;font-weight:700;cursor:pointer;font-family:inherit;transition:opacity .2s}.guide-btn:active{opacity:.85}.guide-btn.primary{background:var(--primary);color:#fff}.guide-btn.secondary{background:#ffffff14;color:var(--text-secondary);border:1px solid rgba(255,255,255,.1)}.guide-skip{background:none;border:none;color:var(--text-muted);font-size:.82rem;cursor:pointer;padding:4px 8px}@keyframes slideUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.fav-sort-row{display:flex;align-items:center;justify-content:space-between;padding:.5rem .25rem .75rem}.fav-count{font-size:.82rem;font-weight:700;color:var(--text-secondary)}.fav-sort-select{padding:6px 10px;border-radius:10px;border:1.5px solid var(--border);background:var(--surface);color:var(--text);font-size:.8rem;font-weight:600;cursor:pointer;font-family:inherit;outline:none}.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{display:flex;justify-content:space-between;align-items:center;margin-bottom:.6rem}.daily-goal-title{font-size:.82rem;font-weight:800;color:var(--text);letter-spacing:.02em}.daily-goal-count{font-size:.75rem;font-weight:700;color:var(--primary)}.daily-goal-bar-bg{height:8px;background:var(--border);border-radius:4px;overflow:hidden;margin-bottom:.45rem}.daily-goal-bar-fill{height:100%;background:linear-gradient(90deg,#4a90d9,#7ed321);border-radius:4px;transition:width .6s ease}.daily-goal-done{font-size:.78rem;font-weight:700;color:#7ed321;text-align:center}.daily-goal-hint{font-size:.72rem;color:var(--text-muted);text-align:center}.ach-toast{position:fixed;top:60px;right:16px;background:linear-gradient(135deg,#1a1a2e,#16213e);border:1.5px solid rgba(255,215,0,.4);border-radius:16px;padding:12px 16px;display:flex;align-items:center;gap:12px;z-index:9998;box-shadow:0 8px 32px #ffd70033,0 4px 16px #0006;animation:achSlideIn .4s cubic-bezier(.34,1.56,.64,1);max-width:280px}@keyframes achSlideIn{0%{opacity:0;transform:translate(60px) scale(.8)}to{opacity:1;transform:translate(0) scale(1)}}.ach-toast-icon{font-size:2.2rem;flex-shrink:0}.ach-toast-title{font-size:.7rem;font-weight:800;color:gold;text-transform:uppercase;letter-spacing:.08em;margin-bottom:2px}.ach-toast-name{font-size:.88rem;font-weight:800;color:#fff;margin-bottom:2px}.ach-toast-desc{font-size:.72rem;color:#fff9}.ach-badges-row{overflow:hidden}.ach-badges-scroll{display:flex;gap:.5rem;overflow-x:auto;scrollbar-width:none;padding-bottom:2px}.ach-badges-scroll::-webkit-scrollbar{display:none}.ach-badge{display:flex;align-items:center;gap:4px;padding:5px 10px;border-radius:20px;border:1.5px solid var(--border);background:var(--surface);flex-shrink:0;transition:all .2s}.ach-badge.locked{opacity:.35;filter:grayscale(1)}.ach-badge.unlocked{border-color:#ffd7004d;background:#ffd70014}.ach-badge-icon{font-size:1.1rem}.ach-badge-name{font-size:.72rem;font-weight:700;color:var(--text);white-space:nowrap}.ach-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.6rem;margin-bottom:.75rem}.ach-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:.75rem .5rem;text-align:center;transition:all .2s}.ach-card.locked{opacity:.4;filter:grayscale(1)}.ach-card.unlocked{border-color:#ffd70040;background:#ffd7000d}.ach-card-icon{font-size:1.6rem;margin-bottom:4px}.ach-card-name{font-size:.68rem;font-weight:800;color:var(--text);margin-bottom:2px}.ach-card-desc{font-size:.6rem;color:var(--text-muted);line-height:1.3}.ach-progress-bar{height:6px;background:var(--border);border-radius:3px;overflow:hidden;margin-bottom:.35rem}.ach-progress-fill{height:100%;background:linear-gradient(90deg,gold,#f5a623);border-radius:3px;transition:width .6s ease}.ach-progress-text{font-size:.7rem;color:var(--text-muted);text-align:center;font-weight:600}.feedback-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b8;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:9000;display:flex;align-items:center;justify-content:center;padding:16px;animation:fadeIn .2s ease}.feedback-modal{background:var(--surface, #1a1a2e);border-radius:20px;width:100%;max-width:380px;overflow:hidden;box-shadow:0 24px 60px #00000080;animation:slideUp .25s ease}.feedback-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;font-size:15px;font-weight:700;color:var(--text, #fff);border-bottom:1px solid rgba(255,255,255,.08)}.feedback-close{background:#ffffff1a;border:none;color:var(--text, #fff);width:28px;height:28px;border-radius:50%;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center}.feedback-close:hover{background:#fff3}.feedback-body{padding:16px 20px;display:flex;flex-direction:column;gap:10px}.feedback-original,.feedback-result{display:flex;gap:8px;font-size:.85rem;color:var(--text-secondary, #aaa)}.feedback-original label,.feedback-result label{font-weight:600;color:var(--text-muted, #888);min-width:40px}.feedback-original span,.feedback-result span{color:var(--text, #fff);font-weight:500}.feedback-text{width:100%;padding:10px 12px;border-radius:12px;border:1.5px solid rgba(255,255,255,.12);background:#ffffff0f;color:var(--text, #fff);font-size:.9rem;font-family:inherit;resize:none;outline:none;box-sizing:border-box}.feedback-text:focus{border-color:var(--primary, #4f46e5);box-shadow:0 0 0 3px #4f46e526}.feedback-submit{padding:12px;border:none;border-radius:14px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:.95rem;font-weight:700;cursor:pointer;transition:all .2s}.feedback-submit:hover{opacity:.9;transform:translateY(-1px)}.stats-panel{margin-bottom:12px;position:sticky;top:0;z-index:50}.stats-toggle{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:8px 16px;font-size:14px;font-weight:600;color:var(--text-secondary);cursor:pointer;width:100%;text-align:left;transition:all .2s}.stats-toggle:hover{border-color:var(--primary);color:var(--primary)}.stats-content{background:var(--surface);border:1px solid var(--border);border-radius:18px;padding:16px;margin-top:8px;text-align:left}.stats-mode-tabs{display:flex;gap:6px;margin-bottom:16px}.stats-mode-tab{flex:1;padding:8px 4px;background:transparent;border:1px solid var(--border);border-radius:10px;font-size:13px;cursor:pointer;color:var(--text-secondary);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{display:flex;gap:10px;margin-bottom:16px}.stats-summary-card{flex:1;background:var(--bg);border:1px solid var(--border);border-radius:12px;padding:10px 8px;text-align:center;display:flex;flex-direction:column;gap:4px}.stats-summary-num{font-size:22px;font-weight:800;color:var(--primary)}.stats-summary-label{font-size:11px;color:var(--text-muted)}.stats-section{margin-bottom:14px}.stats-section-title{font-size:13px;font-weight:600;color:var(--text-secondary);margin-bottom:10px}.stats-trend-chart{display:flex;align-items:flex-end;gap:4px;height:80px;padding:0 4px}.stats-trend-bar-wrap{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;height:100%;justify-content:flex-end}.stats-trend-bar{width:100%;max-width:28px;background:linear-gradient(180deg,var(--accent),var(--accent-dark));border-radius:4px 4px 0 0;min-height:4px;transition:height .3s ease}.stats-trend-label{font-size:9px;color:var(--text-muted);white-space:nowrap}.stats-session-list{display:flex;flex-direction:column;gap:6px;max-height:200px;overflow-y:auto}.stats-session-item{display:flex;align-items:center;gap:8px;padding:6px 10px;background:var(--bg);border-radius:10px;border:1px solid var(--border)}.stats-session-date{font-size:11px;color:var(--text-muted);min-width:60px}.stats-bar-track{flex:1;height:6px;background:var(--border);border-radius:3px;overflow:hidden}.stats-bar-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-dark));border-radius:3px;transition:width .4s ease}.stats-session-accuracy{font-size:13px;font-weight:700;color:var(--primary);min-width:36px;text-align:right}.stats-session-score{font-size:11px;color:var(--text-muted);min-width:36px;text-align:right}.stats-empty{text-align:center;padding:20px;color:var(--text-muted)}.stats-empty p{font-size:14px;margin-bottom:4px}.stats-empty-hint{font-size:12px;opacity:.7}.stats-clear-btn{background:transparent;border:1px solid var(--danger);color:var(--danger);border-radius:10px;padding:6px 14px;font-size:12px;cursor:pointer;margin-top:8px;width:100%;transition:all .2s}.stats-clear-btn:hover{background:var(--danger);color:#fff}.flashcard-result-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px;margin:12px 0;max-height:none;overflow-y:visible}.flashcard-result-card{background:var(--surface);border:2px solid var(--border);border-radius:16px;padding:12px 10px;min-height:100px;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;position:relative;text-align:center}.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{display:flex;flex-direction:column;align-items:center;gap:4px}.flashcard-result-front{font-size:14px;font-weight:600;color:var(--text)}.flashcard-result-back{font-size:15px;font-weight:700;color:var(--primary)}.flashcard-result-back .result-card-roman{font-size:11px;color:var(--text-secondary)}.flashcard-result-status{position:absolute;top:6px;right:8px;font-size:12px}.flashcard-result-hint{font-size:10px;color:var(--text-muted);margin-top:4px}.dictation-result-item{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:14px 16px;margin-bottom:10px;text-align:left}.dictation-result-item.correct{border-left:4px solid var(--success)}.dictation-result-item.wrong{border-left:4px solid var(--danger)}.dictation-result-audio{display:flex;align-items:center;gap:8px;margin-bottom:8px}.dictation-result-lo{font-size:18px;font-weight:700;color:var(--primary);flex:1}.dictation-result-replay{background:var(--primary-soft);border:none;border-radius:50%;width:36px;height:36px;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.dictation-result-replay:hover{background:var(--primary);transform:scale(1.1)}.dictation-result-replay.playing{animation:pulse-ring .6s ease-out}@keyframes pulse-ring{0%{box-shadow:0 0 rgba(var(--primary),.4)}to{box-shadow:0 0 0 12px rgba(var(--primary),0)}}.dictation-result-answers{display:flex;gap:10px;margin-top:6px;flex-wrap:wrap}.dictation-result-answer{display:flex;flex-direction:column;gap:2px}.dictation-result-answer-label{font-size:10px;color:var(--text-muted);text-transform:uppercase}.dictation-result-your{font-size:14px;font-weight:600;color:var(--danger)}.dictation-result-correct{font-size:14px;font-weight:600;color:var(--success)}[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){background:#181d38d9;border-color:#8895ff24;color:var(--text-secondary)}[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{background:#34c7591f;color:var(--success);border-color:#34c7594d}.result-mini-bar{display:flex;align-items:center;justify-content:center;gap:12px;padding:10px 16px;background:linear-gradient(135deg,var(--accent) 0%,var(--accent-dark) 100%);border-radius:14px;margin-bottom:16px;width:100%;max-width:340px;color:#fff;font-size:15px;font-weight:700;box-shadow:0 6px 16px #667eea40;flex-wrap:wrap}.result-mini-score{opacity:.9}.result-mini-accuracy{font-size:22px;font-weight:800;color:#fff;text-shadow:0 1px 4px rgba(0,0,0,.2)}.result-mini-delta{font-size:13px;font-weight:600;padding:3px 10px;border-radius:20px;background:#ffffff40;display:flex;align-items:center;gap:2px}.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 (max-width: 520px){.stats-panel{position:sticky;top:0;z-index:50}.stats-content{max-height:60vh;overflow-y:auto}}.result-card-lo{font-size:16px;font-weight:700;color:var(--primary)}.result-quick-review{display:flex;flex-direction:column;gap:6px;padding:12px 16px;background:var(--bg);border:1px solid var(--border);border-radius:14px;margin-bottom:12px;width:100%;max-width:400px}.result-quick-label{font-size:13px;font-weight:600;color:var(--text-secondary)}.result-quick-phrases{display:flex;flex-wrap:wrap;gap:6px}.result-quick-item{padding:4px 10px;background:#ef444414;border:1px solid rgba(239,68,68,.2);border-radius:8px;font-size:14px;font-weight:600;color:var(--danger)}.result-quick-more{padding:4px 8px;font-size:12px;color:var(--text-muted);align-self:center}[data-theme=dark] .result-quick-item{background:#ef444426;border-color:#ef44444d}.review-status-banner{display:flex;align-items:center;gap:10px;padding:10px 14px;background:linear-gradient(135deg,var(--accent) 0%,var(--accent-dark) 100%);border-radius:14px;margin-bottom:12px;color:#fff;max-width:340px}.review-status-icon{font-size:20px}.review-status-info{display:flex;flex-direction:column;gap:2px}.review-status-title{font-size:13px;font-weight:700;opacity:.9}.review-status-due{font-size:12px;color:#ffe066;font-weight:600}.review-status-done{font-size:12px;opacity:.8}[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{display:flex;align-items:center;gap:12px;padding:16px 0;position:sticky;top:0;background:var(--bg);z-index:10}.wordpacks-page .page-header h2{margin:0;font-size:18px}.wordpacks-page .back-btn{background:var(--card-bg);border:none;padding:8px 16px;border-radius:8px;color:var(--text);cursor:pointer;font-size:14px}.packs-section{margin-bottom:24px}.section-title{font-size:14px;color:var(--text-secondary);margin-bottom:12px;padding-left:4px}.wordpack-card{background:var(--card-bg);border-radius:12px;padding:16px;margin-bottom:12px}.wordpack-header{display:flex;gap:12px;margin-bottom:12px}.wordpack-lang-badge{background:var(--primary);color:#fff;padding:4px 8px;border-radius:6px;font-size:12px;font-weight:600;height:fit-content}.wordpack-title{margin:0 0 6px;font-size:16px}.wordpack-desc{margin:0 0 8px;font-size:13px;color:var(--text-secondary);line-height:1.4}.wordpack-meta{display:flex;gap:12px;font-size:12px;color:var(--text-secondary)}.wordpack-meta .dl-badge{color:var(--success, #4caf50)}.wordpack-actions{display:flex;gap:8px}.wp-btn{flex:1;padding:10px 16px;border:none;border-radius:8px;font-size:14px;cursor:pointer;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:0 0 auto;padding:10px 12px}.loading{text-align:center;padding:40px;color:var(--text-secondary)}.error-msg{background:#fee;color:#c00;padding:12px 16px;border-radius:8px;margin:16px 0}.empty-state{text-align:center;padding:60px 20px;color:var(--text-secondary)}.page.wordbrowse-page{padding:0 0 6rem;min-height:100vh}.wb-header{display:flex;align-items:center;gap:.5rem;padding:.8rem 1rem;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:20;background:var(--bg)}.wb-title{flex:1;font-size:1.1rem;font-weight:700;margin:0}.back-btn{background:none;border:none;font-size:1rem;color:var(--text);cursor:pointer;padding:4px 8px;border-radius:8px}.back-btn:active{background:var(--surface)}.wb-learn-btn{padding:6px 14px;background:var(--primary);color:#fff;border:none;border-radius:20px;font-size:.85rem;cursor:pointer}.wb-empty{display:flex;flex-direction:column;align-items:center;padding:4rem 2rem;text-align:center}.wb-empty-icon{font-size:3rem;margin-bottom:.5rem}.wb-empty p{margin:0;font-size:1rem;font-weight:500}.wb-empty-sub{font-size:.85rem!important;color:var(--text-secondary);margin-top:.3rem!important}.wb-pack-list{padding:.5rem 1rem}.wb-section-title{font-size:.78rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;padding:.8rem 0 .4rem}.wb-pack-item{display:flex;align-items:center;gap:.75rem;padding:.9rem 1rem;background:var(--surface);border-radius:14px;border:1px solid var(--border);cursor:pointer;margin-bottom:.5rem;transition:all .15s}.wb-pack-item:active{transform:scale(.98);background:var(--hover-bg)}.wb-pack-icon{font-size:1.5rem}.wb-pack-body{flex:1}.wb-pack-name{font-weight:600;font-size:1rem}.wb-pack-desc{font-size:.8rem;color:var(--text-secondary);margin-top:2px}.wb-pack-arrow{font-size:1.3rem;color:var(--text-muted)}.wb-search-bar{padding:.5rem 1rem 0}.wb-search-wrap{display:flex;align-items:center;gap:.5rem;background:var(--surface);border:1.5px solid var(--border);border-radius:12px;padding:0 .75rem}.wb-search-icon{font-size:.9rem;color:var(--text-muted);flex-shrink:0}.wb-search{flex:1;padding:10px 0;border:none;outline:none;background:transparent;color:var(--text);font-size:.95rem}.wb-search::placeholder{color:var(--text-muted)}.wb-search-clear{background:none;border:none;font-size:.8rem;color:var(--text-muted);cursor:pointer;padding:2px 4px}.wb-count-bar{display:flex;gap:1rem;padding:.35rem .25rem;font-size:.78rem;color:var(--text-secondary)}.wb-count-highlight{color:var(--primary);font-weight:600}.wb-card{margin:1rem;padding:1.8rem 1.5rem;background:var(--surface);border-radius:20px;border:1px solid var(--border);text-align:center;cursor:pointer;box-shadow:0 2px 16px #00000012;position:relative}.wb-card-word{font-size:2.2rem;font-weight:800;color:var(--text);margin-bottom:.25rem;letter-spacing:.02em}.wb-card-pinyin{font-size:.85rem;color:var(--text-muted);margin-bottom:.5rem}.wb-card-zh{font-size:1.35rem;color:var(--text-secondary);margin-bottom:.25rem}.wb-card-en{font-size:.82rem;color:var(--text-muted)}.wb-card-actions{display:flex;justify-content:center;gap:.8rem;margin-top:1.2rem}.wb-action-btn{width:44px;height:44px;border-radius:50%;border:1.5px solid var(--border);background:var(--surface);font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.wb-action-btn:active{transform:scale(.9)}.wb-action-btn.active{border-color:#e91e63;background:#e91e6314}.wb-action-btn.playing{border-color:var(--primary);background:#4a90d914}.wb-nav{display:flex;align-items:center;justify-content:center;gap:1.5rem;padding:.8rem 1rem}.wb-nav-btn{width:44px;height:44px;border-radius:50%;border:1.5px solid var(--border);background:var(--surface);font-size:1.4rem;cursor:pointer;color:var(--text);display:flex;align-items:center;justify-content:center}.wb-nav-btn:active:not(:disabled){transform:scale(.93)}.wb-nav-btn:disabled{opacity:.3;cursor:not-allowed}.wb-counter{font-size:.9rem;color:var(--text-secondary);min-width:70px;text-align:center}.wb-list-section{padding:0 1rem 2rem}.wb-list{border-radius:14px;border:1px solid var(--border);overflow:hidden;max-height:45vh;overflow-y:auto}.wb-list-item{display:flex;align-items:center;justify-content:space-between;padding:.75rem .85rem;border-bottom:1px solid var(--border);background:var(--surface);cursor:pointer;transition:background .1s}.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:1;display:flex;flex-direction:column;gap:1px}.wb-list-lo{font-size:.98rem;font-weight:600}.wb-list-zh{font-size:.85rem;color:var(--text-secondary)}.wb-list-actions{display:flex;gap:.3rem;align-items:center}.wb-list-btn{background:none;border:none;font-size:.9rem;cursor:pointer;padding:4px 5px;border-radius:6px}.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 (min-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{padding:12px 6px;border-radius:14px}.channel-icon{font-size:22px}.channel-name{font-size:11px}.tp-history-dropdown{position:absolute;top:100%;left:0;right:0;background:var(--surface);border:1px solid var(--border);border-radius:0 0 14px 14px;z-index:100;box-shadow:0 4px 16px #0000001f;overflow:hidden;max-height:280px;overflow-y:auto}.tp-history-title{font-size:.75rem;font-weight:600;color:var(--text-muted);padding:8px 14px 4px;text-transform:uppercase;letter-spacing:.05em}.tp-history-item{display:flex;align-items:center;justify-content:space-between;padding:8px 14px;cursor:pointer}.tp-history-item:hover{background:var(--hover-bg)}.tp-history-text{font-size:.95rem;color:var(--text)}.tp-history-del{background:none;border:none;font-size:.75rem;color:var(--text-muted);cursor:pointer;padding:2px 4px}.tp-history-clear{width:100%;padding:8px;border:none;border-top:1px solid var(--border);background:none;color:var(--text-muted);font-size:.85rem;cursor:pointer;text-align:center}.tp-history-clear:hover{color:var(--text)}.tp-pack-filter{display:flex;gap:6px;padding:.4rem 1rem;overflow-x:auto;scrollbar-width:none}.tp-pack-filter::-webkit-scrollbar{display:none}.tp-pack-btn{flex-shrink:0;padding:4px 12px;border-radius:16px;border:1.5px solid var(--border);background:var(--surface);color:var(--text-secondary);font-size:.8rem;cursor:pointer;white-space:nowrap}.tp-pack-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.phrase-pinyin{font-size:.78rem;color:var(--text-muted);margin-bottom:2px}.phrase-copy{background:none;border:none;font-size:.85rem;cursor:pointer;padding:4px 6px;border-radius:6px}.phrase-copy:hover{background:#0000000f}.tp-filter-tag{font-size:.75rem;background:var(--primary);color:#fff;padding:2px 8px;border-radius:10px;margin-left:8px}
