:root{--accent: #9b7bff;--accent-2: #c66bff;--accent-3: #36d6ff;--grad: linear-gradient(120deg, #7c5cff 0%, #b15cff 48%, #36d0ff 100%);--grad-vivid: linear-gradient(120deg, #8b6dff, #c06bff 40%, #ff7ad9 70%, #36d0ff);--grad-soft: linear-gradient(120deg, rgba(139, 109, 255, .2), rgba(54, 208, 255, .2));--green: #2ee6a6;--amber: #ffc24b;--pink: #ff7ad9;--red: #ff6b86;--blue: #6aa8ff;--cyan: #36d6ff;--radius: 20px;--radius-sm: 13px;--radius-lg: 28px;--ease: cubic-bezier(.4, 0, .2, 1);--spring: cubic-bezier(.34, 1.56, .64, 1);--font: "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;--font-display: "Sora", var(--font);--glow: 0 0 0 1px rgba(155, 123, 255, .35), 0 12px 40px -12px rgba(124, 92, 255, .55);--glow-strong: 0 0 30px -6px rgba(155, 123, 255, .7)}:root,[data-theme=dark]{--bg: #060510;--bg-2: #0d0b1c;--surface: rgba(255, 255, 255, .04);--surface-2: rgba(255, 255, 255, .065);--surface-hover: rgba(255, 255, 255, .11);--border: rgba(255, 255, 255, .08);--border-strong: rgba(255, 255, 255, .16);--text: #f1eefc;--muted: rgba(228, 225, 248, .72);--glass: rgba(16, 14, 30, .66);--ring: linear-gradient(160deg, rgba(255, 255, 255, .18), rgba(255, 255, 255, .02));--shadow: 0 24px 60px -24px rgba(4, 2, 16, .8), 0 2px 8px -2px rgba(0, 0, 0, .4);--shadow-sm: 0 8px 24px -12px rgba(0, 0, 0, .6);color-scheme:dark}[data-theme=light]{--bg: #eef0fb;--bg-2: #e6e9fb;--surface: rgba(255, 255, 255, .72);--surface-2: rgba(255, 255, 255, .92);--surface-hover: #ffffff;--border: rgba(30, 27, 75, .08);--border-strong: rgba(30, 27, 75, .15);--text: #191634;--muted: rgba(25, 22, 52, .72);--glass: rgba(255, 255, 255, .78);--ring: linear-gradient(160deg, rgba(255, 255, 255, .9), rgba(255, 255, 255, .3));--shadow: 0 24px 60px -26px rgba(70, 60, 140, .45), 0 2px 8px -3px rgba(70, 60, 140, .15);--shadow-sm: 0 8px 24px -14px rgba(70, 60, 140, .35);--glow: 0 0 0 1px rgba(124, 92, 255, .25), 0 14px 40px -14px rgba(124, 92, 255, .4);color-scheme:light}*{box-sizing:border-box}html,body{margin:0;padding:0}html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}button,.word-main,.flashcard,.topic-card,.quiz-option,.mnav-item{-webkit-tap-highlight-color:transparent}.word-main,.flashcard,.card-word{user-select:none;-webkit-user-select:none}body{font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden}button,input,select{font-family:inherit;color:inherit}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}h1,h2,h3{font-family:var(--font-display);font-weight:700;letter-spacing:-.02em;margin:0}::selection{background:#8b6dff59}.aurora{position:fixed;inset:-35% -15% auto -15%;height:110vh;height:110dvh;z-index:0;pointer-events:none;background:radial-gradient(38% 48% at 18% 16%,rgba(124,92,255,.4),transparent 72%),radial-gradient(34% 42% at 82% 8%,rgba(54,214,255,.3),transparent 72%),radial-gradient(40% 50% at 62% 58%,rgba(198,107,255,.32),transparent 72%),radial-gradient(28% 36% at 40% 80%,rgba(255,122,217,.18),transparent 72%);filter:blur(48px) saturate(1.2);animation:drift 26s var(--ease) infinite alternate}[data-theme=light] .aurora{opacity:.7}.app-shell:after{content:"";position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;opacity:.035;mix-blend-mode:overlay;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}@keyframes drift{0%{transform:translate3d(-4%,-2%,0) scale(1) rotate(0)}to{transform:translate3d(5%,4%,0) scale(1.15) rotate(4deg)}}.app-shell{position:relative;z-index:1;min-height:100vh;min-height:100dvh}.content{position:relative;padding:16px 16px 96px;max-width:1100px;margin:0 auto}.mobile-header{position:sticky;top:0;z-index:30;display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--glass);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border-bottom:1px solid var(--border)}.mobile-nav{position:fixed;bottom:0;left:0;right:0;z-index:40;display:grid;grid-template-columns:repeat(6,1fr);gap:2px;padding:9px 6px calc(9px + env(safe-area-inset-bottom));background:var(--glass);backdrop-filter:blur(24px) saturate(1.4);-webkit-backdrop-filter:blur(24px) saturate(1.4);border-top:1px solid var(--border);box-shadow:0 -10px 30px -16px #00000080}.mnav-item{display:flex;flex-direction:column;align-items:center;gap:3px;background:none;border:0;padding:4px 2px;border-radius:12px;color:var(--muted);font-size:10px;font-weight:600;cursor:pointer;transition:color .2s var(--ease)}.mnav-icon{position:relative;display:grid;place-items:center;width:44px;height:32px;border-radius:11px;transition:all .3s var(--spring)}.mnav-item.active{color:var(--text)}.mnav-item.active .mnav-icon{background:var(--grad);color:#fff;transform:translateY(-2px) scale(1.06);box-shadow:0 10px 22px -6px #7c5cffcc,inset 0 1px #ffffff4d}.mnav-badge{position:absolute;top:-4px;right:-2px;background:var(--amber);color:#1a1300;font-size:9px;font-weight:800;min-width:15px;height:15px;border-radius:8px;display:grid;place-items:center;padding:0 3px}.sidebar{display:none}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 18px;border-radius:12px;border:1px solid transparent;font-weight:600;font-size:14px;cursor:pointer;transition:transform .15s var(--ease),box-shadow .2s var(--ease),background .2s var(--ease);white-space:nowrap}.btn:active{transform:scale(.96)}.btn:disabled{opacity:.45;cursor:not-allowed}.btn.full{width:100%;margin-top:8px}.btn-primary{position:relative;background:var(--grad);background-size:140% 140%;color:#fff;box-shadow:0 12px 30px -10px #7c5cffbf,inset 0 1px #ffffff40;overflow:hidden}.btn-primary:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(110deg,transparent 30%,rgba(255,255,255,.4) 50%,transparent 70%);transform:translate(-130%);transition:transform .7s var(--ease)}.btn-primary:hover:not(:disabled){box-shadow:0 18px 42px -10px #7c5cffe6,inset 0 1px #ffffff4d;transform:translateY(-2px)}.btn-primary:hover:not(:disabled):after{transform:translate(130%)}.btn-ghost{background:var(--surface-2);border-color:var(--border);color:var(--text)}.btn-ghost:hover:not(:disabled){background:var(--surface-hover)}.btn-green{background:#34d39929;border-color:#34d39966;color:var(--green)}.btn-amber{background:#fbbf2424;border-color:#fbbf2461;color:var(--amber)}.btn-danger{background:var(--red);color:#fff}.btn-danger-soft{background:#fb6f841f;border-color:#fb6f8459;color:var(--red)}.icon-btn{display:inline-grid;place-items:center;width:34px;height:34px;border-radius:10px;border:1px solid transparent;background:transparent;color:var(--muted);cursor:pointer;transition:all .18s var(--ease)}.icon-btn:hover{background:var(--surface-2);color:var(--text)}.icon-btn.on{background:var(--grad-soft);color:var(--accent)}.icon-btn.on-green{background:#34d39929;color:var(--green)}.icon-btn.on-amber{background:#fbbf2429;color:var(--amber)}.icon-btn.danger:hover{background:#fb6f8429;color:var(--red)}.icon-btn.chevron{transition:transform .25s var(--ease),background .18s}.icon-btn.chevron.flip{transform:rotate(180deg)}.chip{display:inline-flex;align-items:center;gap:6px;padding:8px 13px;border-radius:999px;border:1px solid var(--border);background:var(--surface);color:var(--text);font-size:13px;font-weight:600;cursor:pointer;transition:all .18s var(--ease)}.chip:hover:not(:disabled){background:var(--surface-hover);border-color:var(--border-strong)}.chip:disabled{opacity:.4;cursor:not-allowed}.chip-active{background:var(--grad-soft);border-color:#8b6dff80;color:var(--accent)}.search{display:flex;align-items:center;gap:8px;padding:9px 12px;border-radius:12px;background:var(--surface);border:1px solid var(--border);color:var(--muted);min-width:0;transition:border-color .2s var(--ease)}.search:focus-within{border-color:var(--accent)}.search input{border:0;background:none;outline:none;font-size:14px;width:100%;min-width:0}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}.field>span{font-size:12px;font-weight:600;color:var(--muted)}.field input,.field select,.add-row input,.topic-manage-row input{padding:11px 13px;border-radius:11px;border:1px solid var(--border);background:var(--surface);outline:none;font-size:14px;transition:border-color .2s var(--ease);width:100%}.field input:focus,.field select:focus,.add-row input:focus{border-color:var(--accent)}.page{animation:rise .45s var(--ease) both}.view-fade{animation:rise .4s var(--ease) both}@keyframes rise{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}.page-head{display:flex;flex-direction:column;gap:14px;margin-bottom:18px}.page-head h1{font-size:clamp(30px,8vw,44px);line-height:1.02;letter-spacing:-.035em;font-weight:800}.page-head .muted{margin:8px 0 0;font-size:14.5px;max-width:60ch}.muted{color:var(--muted)}.small{font-size:13px}.grad-text{background:var(--grad-vivid);background-size:200% auto;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;animation:hue 8s linear infinite}@keyframes hue{to{background-position:200% center}}.toolbar{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:10px;margin-bottom:16px}.chips{display:flex;flex-wrap:wrap;gap:8px}.toolbar-info{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--muted)}.toolbar-info strong{color:var(--text)}.app-footer{text-align:center;margin-top:30px;font-size:12px;color:var(--muted)}.center-fill{min-height:70vh;min-height:70dvh;display:grid;place-items:center}.error-card{text-align:center;padding:30px;border-radius:var(--radius);background:var(--surface);border:1px solid var(--border);max-width:380px}.topic-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}.topic-card{position:relative;text-align:left;padding:17px;border-radius:var(--radius);border:1px solid var(--border);background:linear-gradient(160deg,#ffffff0d,#fff0) padding-box,var(--surface) padding-box;cursor:pointer;overflow:hidden;display:flex;flex-direction:column;gap:12px;min-height:142px;transition:transform .28s var(--spring),border-color .2s var(--ease),box-shadow .3s var(--ease);animation:pop .5s var(--spring) both;animation-delay:calc(var(--i) * 22ms)}@keyframes pop{0%{opacity:0;transform:translateY(16px) scale(.96)}to{opacity:1;transform:none}}.topic-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(120% 90% at 0% 0%,rgba(124,92,255,.22),transparent 60%);opacity:0;transition:opacity .3s var(--ease)}.topic-card:hover{transform:translateY(-5px) scale(1.01);border-color:var(--border-strong);box-shadow:var(--shadow)}.topic-card:hover:before{opacity:.7}.topic-card.selected{border-color:transparent;box-shadow:var(--glow)}.topic-card.selected:before{opacity:1}.topic-card>*{position:relative;z-index:1}.topic-card-top{display:flex;justify-content:space-between;align-items:center}.topic-index{font-family:var(--font-display);font-size:13px;font-weight:700;color:var(--muted);letter-spacing:.05em}.select-dot{width:22px;height:22px;border-radius:7px;border:1.5px solid var(--border-strong);display:grid;place-items:center;color:#fff;transition:all .2s var(--ease)}.select-dot.on{background:var(--grad);border-color:transparent}.topic-name{font-size:16px;line-height:1.2;flex:1}.topic-card-foot{display:flex;align-items:flex-end;justify-content:space-between;gap:8px}.topic-meta{display:flex;flex-direction:column;gap:5px}.count-pill{font-size:11px;font-weight:600;color:var(--muted);background:var(--surface-2);padding:3px 8px;border-radius:999px;width:fit-content}.known-pill{font-size:11px;font-weight:700;color:var(--green);background:#34d39924;padding:3px 8px;border-radius:999px;width:fit-content}.launch-bar{margin:20px 0 4px;display:flex;flex-direction:column;gap:10px;padding:12px 14px;border-radius:14px;background:var(--surface);border:1px solid var(--border)}.launch-lead{margin:0;font-size:13px;color:var(--muted)}.launch-num{font-family:var(--font-display);font-weight:800;font-size:15px;background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.launch-actions{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.launch-btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:10px 12px;border-radius:11px;border:1px solid var(--border);background:var(--surface-2);color:var(--text);font-size:13px;font-weight:600;cursor:pointer;white-space:nowrap;transition:transform .14s var(--ease),background .16s var(--ease),box-shadow .18s var(--ease)}.launch-btn:hover{background:var(--surface-hover)}.launch-btn:active{transform:scale(.97)}.launch-btn.primary{background:var(--grad);border-color:transparent;color:#fff;box-shadow:0 10px 22px -10px #8b6dffb3}.launch-btn.primary:hover{box-shadow:0 14px 28px -10px #8b6dffd9}.ring{position:relative;display:grid;place-items:center;flex-shrink:0}.ring svg{position:absolute;top:0;right:0;bottom:0;left:0}.ring-track{stroke:var(--border)}.ring-value{stroke:url(#ringgrad);stroke:var(--accent);transition:stroke-dashoffset .8s var(--ease)}.ring-label{font-size:11px;font-weight:700}.ring-pct{font-size:11px;font-weight:800;color:var(--text)}.spinner-wrap{display:flex;flex-direction:column;align-items:center;gap:14px}.spinner{width:38px;height:38px;border-radius:50%;border:3px solid var(--border);border-top-color:var(--accent);animation:spin .8s linear infinite}.spin{animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.skel{border-radius:var(--radius-sm);background:linear-gradient(100deg,var(--surface) 30%,var(--surface-hover) 50%,var(--surface) 70%);background-size:200% 100%;animation:shimmerSkel 1.3s var(--ease) infinite}@keyframes shimmerSkel{to{background-position:-200% 0}}.skel-title{height:38px;width:min(70%,320px);margin-bottom:12px}.skel-sub{height:16px;width:min(90%,460px);margin-bottom:22px}.skel-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}.skel-card{height:142px}.offline-banner{display:flex;align-items:center;gap:9px;margin:0 0 14px;padding:10px 14px;border-radius:12px;font-size:13px;font-weight:600;color:var(--amber);background:#ffc24b1f;border:1px solid rgba(255,194,75,.35)}.review-banner{display:flex;align-items:center;gap:12px;width:100%;text-align:left;margin-bottom:18px;padding:14px 16px;border-radius:var(--radius);border:1px solid rgba(139,109,255,.35);background:var(--grad-soft);color:var(--text);cursor:pointer;transition:transform .14s var(--ease),box-shadow .2s var(--ease),border-color .2s var(--ease)}.review-banner:hover{box-shadow:var(--glow);border-color:#8b6dff99}.review-banner:active{transform:scale(.99)}.review-banner-icon{display:grid;place-items:center;width:42px;height:42px;flex-shrink:0;border-radius:12px;color:#fff;background:var(--grad);box-shadow:0 8px 20px -8px #7c5cffcc}.review-banner-text{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.review-banner-text strong{font-size:15px}.review-banner-text .muted{font-size:12.5px}.review-banner-go{color:var(--accent);flex-shrink:0}.review-cta{display:flex;align-items:center;gap:10px;margin-top:18px;padding:12px 14px;border-radius:12px;border:1px solid transparent;background:var(--grad);color:#fff;font-size:14px;font-weight:700;cursor:pointer;box-shadow:0 10px 24px -10px #7c5cffcc;transition:transform .14s var(--ease),box-shadow .2s var(--ease)}.review-cta:hover{transform:translateY(-1px);box-shadow:0 14px 30px -10px #7c5cffe6}.review-cta.active{outline:2px solid rgba(255,255,255,.5);outline-offset:1px}.review-cta-badge{margin-left:auto;min-width:22px;height:22px;padding:0 6px;border-radius:11px;background:#ffffff40;display:grid;place-items:center;font-size:12px;font-weight:800}.new-tag{margin-left:8px;font-size:9px;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:var(--green);background:#2ee6a629;padding:2px 6px;border-radius:999px;vertical-align:middle}.empty-state{text-align:center;padding:60px 20px;display:flex;flex-direction:column;align-items:center;gap:10px}.empty-icon{width:64px;height:64px;border-radius:20px;display:grid;place-items:center;background:var(--grad-soft);color:var(--accent);margin-bottom:6px}.empty-state .btn{margin-top:10px}.word-list{display:flex;flex-direction:column;gap:8px}.word-row{position:relative;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface);overflow:hidden;transition:border-color .2s var(--ease),background .2s var(--ease),transform .2s var(--ease),box-shadow .2s var(--ease)}.word-row:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:transparent;transition:background .2s var(--ease)}.word-row:hover{border-color:var(--border-strong);box-shadow:var(--shadow-sm)}.word-row.marked{border-color:#ffc24b73;background:linear-gradient(90deg,rgba(255,194,75,.08),transparent 40%)}.word-row.marked:before{background:var(--amber)}.word-row.known{border-color:#2ee6a666}.word-row.known:before{background:var(--green)}.word-line{display:flex;align-items:center;gap:10px;padding:11px 12px;cursor:pointer}.word-num{font-size:12px;font-weight:700;color:var(--muted);min-width:22px;text-align:center}.word-core{flex:1;min-width:0}.word-head{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.word-main{background:none;border:0;padding:0;cursor:pointer;text-align:left}.word-text{font-size:16px;font-weight:700;font-family:var(--font-display)}.word-row.marked .word-text{color:var(--amber)}.pos-badge{font-size:10px;font-weight:700;text-transform:lowercase;color:var(--accent-3);background:#36d0ff21;padding:2px 7px;border-radius:6px}.root-badge{font-size:10px;font-weight:700;color:var(--accent-2);background:#c06bff24;padding:2px 7px;border-radius:6px}.word-meaning-preview{margin:3px 0 0;font-size:13px;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.word-topic{display:none;font-size:11px;color:var(--muted);background:var(--surface-2);padding:4px 9px;border-radius:999px;white-space:nowrap}.word-actions{display:flex;align-items:center;gap:2px}.word-actions .icon-btn{width:30px;height:30px}.word-detail{overflow:hidden}.word-detail-inner{padding:4px 14px 14px 44px;display:flex;flex-direction:column;gap:10px}.meaning-list{margin:4px 0;padding-left:18px;display:flex;flex-direction:column;gap:5px;font-size:14px}.meaning-list li::marker{color:var(--accent)}.chip-row{display:flex;align-items:center;flex-wrap:wrap;gap:6px}.chip-label{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;margin-right:2px}.word-chip{font-size:12px;font-weight:600;padding:4px 10px;border-radius:999px;background:var(--surface-2);border:1px solid var(--border);color:var(--text);transition:all .15s var(--ease)}.word-chip:hover{border-color:var(--accent);text-decoration:none}.word-chip.rel{background:#c06bff1a;border-color:#c06bff40;color:var(--accent-2)}.phonetic{font-size:13px;color:var(--muted);font-style:italic}.word-example{margin:2px 0;font-size:13.5px;font-style:italic;color:var(--muted);padding-left:12px;border-left:2px solid var(--border-strong)}.detail-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}.detail-btn{display:inline-flex;align-items:center;gap:6px;padding:9px 13px;border-radius:10px;border:1px solid var(--border);background:var(--surface-2);color:var(--text);font-size:13px;font-weight:600;cursor:pointer;transition:all .16s var(--ease)}.detail-btn:hover{background:var(--surface-hover);border-color:var(--border-strong)}.detail-btn.google{background:var(--grad-soft);border-color:#8b6dff66;color:var(--accent)}.detail-btn.is-known{background:#34d39924;border-color:#34d39966;color:var(--green)}.def-loading{display:inline-flex;align-items:center;gap:8px;font-size:13px;color:var(--muted)}.marked-list{margin:0;padding-left:22px;display:flex;flex-direction:column;gap:6px;max-height:50vh;overflow-y:auto}.flashcards-page{display:flex;flex-direction:column}.deck-progress{display:flex;align-items:center;gap:12px;margin-bottom:18px}.deck-progress-bar{flex:1;height:7px;border-radius:999px;background:var(--surface-2);overflow:hidden}.deck-progress-fill{display:block;height:100%;border-radius:999px;background:var(--grad)}.deck-count{font-size:12px;font-weight:600;color:var(--muted);white-space:nowrap}.flashcard-stage{perspective:1600px;display:grid;place-items:center;padding:8px 0 22px;min-height:340px}.flashcard-wrap{width:100%;max-width:440px;cursor:grab}.flashcard-wrap:active{cursor:grabbing}.flashcard{position:relative;width:100%;height:340px;transform-style:preserve-3d;cursor:pointer}.flashcard-face{position:absolute;top:0;right:0;bottom:0;left:0;backface-visibility:hidden;-webkit-backface-visibility:hidden;border-radius:var(--radius-lg);border:1px solid var(--border-strong);padding:28px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:12px;box-shadow:var(--shadow);overflow:hidden}.flashcard-face:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(90% 70% at 50% -10%,rgba(124,92,255,.28),transparent 70%);pointer-events:none}.flashcard-face.front{background:linear-gradient(165deg,var(--surface-2),var(--surface))}.flashcard-face.back{background:linear-gradient(160deg,#7c5cff38,#36d6ff1f),var(--glass);transform:rotateY(180deg);justify-content:flex-start;padding-top:42px;box-shadow:var(--shadow),var(--glow-strong)}.card-topic{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--accent)}.card-word{font-size:clamp(30px,9vw,46px);line-height:1.1}.card-meaning{font-size:17px;line-height:1.5;margin:8px 0 0}.card-speak{margin-top:6px}.flip-hint{position:absolute;bottom:18px;font-size:12px;color:var(--muted)}.card-example{font-size:13.5px;font-style:italic;color:var(--muted);margin:10px 0 0;line-height:1.45}.card-syns{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--muted);margin-top:12px}.card-syns.rel{color:var(--accent-2)}.card-google{display:inline-flex;align-items:center;gap:6px;margin-top:16px;padding:8px 14px;border-radius:999px;background:var(--grad-soft);border:1px solid rgba(139,109,255,.4);color:var(--accent);font-size:13px;font-weight:600}.card-google:hover{text-decoration:none;background:var(--surface-hover)}.flashcard-controls{display:flex;align-items:center;justify-content:center;gap:10px;flex-wrap:wrap}.round-btn{width:46px;height:46px;border-radius:50%;display:grid;place-items:center;border:1px solid var(--border);background:var(--surface-2);color:var(--text);cursor:pointer;transition:all .18s var(--ease)}.round-btn:hover{background:var(--surface-hover);transform:scale(1.05)}.reset-line{display:inline-flex;align-items:center;gap:6px;margin:16px auto 0;background:none;border:0;color:var(--muted);font-size:12px;font-weight:600;cursor:pointer}@media(max-width:899px){.flashcards-page{display:flex;flex-direction:column;height:calc(100dvh - 175px);min-height:340px}.flashcards-page .page-head{margin-bottom:8px}.flashcards-page .page-head p.muted{display:none}.flashcards-page .deck-progress{margin-bottom:10px}.flashcard-stage{flex:1 1 auto;min-height:0;padding:2px 0 8px}.flashcard-wrap{height:100%;max-width:420px}.flashcard{height:100%}.flashcard-face{padding:20px}.flashcard-face.back{padding-top:26px}.reset-line{margin-top:8px}}.seg{display:inline-flex;padding:4px;border-radius:12px;background:var(--surface-2);border:1px solid var(--border);gap:2px}.seg button{border:0;background:none;padding:8px 12px;border-radius:9px;font-size:12px;font-weight:600;color:var(--muted);cursor:pointer;transition:all .18s var(--ease);white-space:nowrap}.seg button.on{background:var(--grad);color:#fff}.quiz-meta{display:flex;align-items:center;gap:12px;margin-bottom:16px}.quiz-bar{flex:1;height:7px;border-radius:999px;background:var(--surface-2);overflow:hidden}.quiz-bar-fill{display:block;height:100%;background:var(--grad);border-radius:999px;transition:width .4s var(--ease)}.quiz-count{font-size:12px;font-weight:600;color:var(--muted);white-space:nowrap}.quiz-card{border-radius:var(--radius-lg);border:1px solid var(--border);background:var(--surface);padding:22px;box-shadow:var(--shadow)}.quiz-topic{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--accent)}.quiz-prompt{margin:12px 0 22px;min-height:64px;display:flex;align-items:center}.quiz-def{font-size:19px;line-height:1.45;font-weight:500;margin:0}.quiz-word{font-size:clamp(28px,8vw,40px)}.quiz-options{display:flex;flex-direction:column;gap:10px}.quiz-option{display:flex;align-items:center;justify-content:space-between;gap:10px;text-align:left;padding:15px 16px;border-radius:14px;border:1px solid var(--border);background:var(--surface-2);color:var(--text);font-size:15px;font-weight:600;cursor:pointer;transition:all .18s var(--ease)}.quiz-option:hover{border-color:var(--accent);transform:translateY(-1px)}.quiz-option.correct{background:#34d39929;border-color:var(--green);color:var(--green)}.quiz-option.wrong{background:#fb6f8424;border-color:var(--red);color:var(--red)}.quiz-option.dim{opacity:.5}.opt-text{flex:1}.quiz-foot{margin-top:18px;display:flex;flex-direction:column;gap:14px}.quiz-foot-actions{display:flex;align-items:center;gap:10px}.quiz-foot-actions .btn{flex:1}.quiz-answer{font-size:14px;line-height:1.5;color:var(--muted)}.quiz-answer strong{color:var(--text)}.quiz-answer .pos,.meaning-list .pos,.quiz-answer em.pos{color:var(--accent-3);font-style:normal;font-weight:600;margin:0 6px;font-size:12px}.quiz-result{text-align:center;display:flex;flex-direction:column;align-items:center;gap:14px;padding:40px 20px}.result-ring{width:120px;height:120px;border-radius:50%;display:grid;place-items:center;gap:2px;color:#fff;position:relative}.result-ring.good{background:radial-gradient(circle at 30% 30%,#34d399,#059669);box-shadow:0 16px 40px -12px #34d399b3}.result-ring.ok{background:radial-gradient(circle at 30% 30%,#fbbf24,#d97706);box-shadow:0 16px 40px -12px #fbbf2499}.result-ring.low{background:radial-gradient(circle at 30% 30%,#fb6f84,#e11d48);box-shadow:0 16px 40px -12px #fb6f8499}.result-pct{font-family:var(--font-display);font-size:22px;font-weight:800}.result-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin-top:6px}.manage-grid{display:grid;gap:14px}.panel{border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);padding:18px}.panel h3{display:flex;align-items:center;gap:8px;font-size:15px;margin-bottom:14px}.add-row{display:flex;gap:8px;margin-bottom:12px}.add-row input{flex:1}.topic-manage-list,.word-manage-list{display:flex;flex-direction:column;gap:6px;max-height:320px;overflow-y:auto;padding-right:2px}.topic-manage-row,.word-manage-row{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:10px;border:1px solid var(--border);background:var(--surface-2)}.topic-manage-row.active{border-color:#8b6dff80}.topic-manage-row input{flex:1}.topic-pick{flex:1;display:flex;align-items:center;justify-content:space-between;gap:8px;background:none;border:0;color:var(--text);font-size:14px;font-weight:600;cursor:pointer;text-align:left}.row-actions{display:flex;gap:2px}.row-actions .icon-btn{width:30px;height:30px}.wm-text{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.wm-text span{font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.yours-badge{margin-left:7px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--accent);background:var(--grad-soft);padding:2px 7px;border-radius:999px;vertical-align:middle}.stat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:16px}.stat-card{border-radius:var(--radius);border:1px solid var(--border);background:linear-gradient(160deg,#ffffff0d,#fff0),var(--surface);padding:18px;display:flex;flex-direction:column;gap:4px;position:relative;overflow:hidden;transition:transform .25s var(--spring),box-shadow .3s var(--ease)}.stat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}.stat-card:after{content:"";position:absolute;top:-50px;right:-50px;width:130px;height:130px;border-radius:50%;opacity:.22;filter:blur(10px);background:currentColor}.stat-icon{width:40px;height:40px;border-radius:12px;display:grid;place-items:center;margin-bottom:8px;background:var(--surface-2)}.stat-value{font-family:var(--font-display);font-size:30px;font-weight:800;line-height:1}.stat-label{font-size:13px;color:var(--muted);font-weight:500}.tone-violet{color:var(--accent)}.tone-cyan{color:var(--cyan)}.tone-green{color:var(--green)}.tone-amber{color:var(--amber)}.tone-pink{color:var(--pink)}.tone-blue{color:var(--blue)}.stat-card .stat-value,.stat-card .stat-label{color:var(--text)}.stat-card .stat-icon{color:inherit}.stats-lower{display:grid;gap:14px}.overall-panel{display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center}.overall-pct{font-family:var(--font-display);font-size:30px;font-weight:800}.topics-progress h3{margin-bottom:16px}.topic-bars{display:flex;flex-direction:column;gap:11px}.topic-bar-row{display:grid;grid-template-columns:1fr 1.4fr auto;align-items:center;gap:10px}.tb-name{font-size:13px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tb-track{height:8px;border-radius:999px;background:var(--surface-2);overflow:hidden}.tb-fill{display:block;height:100%;border-radius:999px;background:var(--grad)}.tb-count{font-size:12px;font-weight:600;color:var(--muted);white-space:nowrap}.toast-viewport{position:fixed;z-index:100;left:50%;transform:translate(-50%);bottom:calc(86px + env(safe-area-inset-bottom));display:flex;flex-direction:column;gap:10px;width:min(420px,calc(100vw - 24px))}.toast{display:flex;align-items:flex-start;gap:11px;padding:13px 14px;border-radius:14px;background:var(--glass);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border:1px solid var(--border-strong);box-shadow:var(--shadow);animation:toastIn .35s var(--ease) both}@keyframes toastIn{0%{opacity:0;transform:translateY(16px) scale(.96)}to{opacity:1;transform:none}}.toast-icon{flex-shrink:0;margin-top:1px}.toast-success .toast-icon{color:var(--green)}.toast-error .toast-icon{color:var(--red)}.toast-info .toast-icon{color:var(--accent-3)}.toast-warn .toast-icon{color:var(--amber)}.toast-body{flex:1;display:flex;flex-direction:column;gap:2px}.toast-body strong{font-size:14px}.toast-body span{font-size:13px;color:var(--muted)}.toast-close{background:none;border:0;color:var(--muted);cursor:pointer;padding:2px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:90;background:#05040c99;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:grid;place-items:center;padding:16px;animation:fade .2s var(--ease)}@keyframes fade{0%{opacity:0}}.modal-card{width:min(460px,100%);border-radius:var(--radius);background:var(--bg-2);border:1px solid var(--border-strong);box-shadow:var(--shadow);animation:rise .3s var(--ease) both;max-height:86vh;display:flex;flex-direction:column}.modal-head{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;border-bottom:1px solid var(--border)}.modal-head h3{font-size:17px}.modal-body{padding:18px;overflow-y:auto}.modal-foot{display:flex;justify-content:flex-end;gap:10px;padding:14px 18px;border-top:1px solid var(--border)}.brand{display:flex;align-items:center;gap:10px}.brand-mark{width:38px;height:38px;border-radius:12px;background:var(--grad);background-size:160% 160%;display:grid;place-items:center;color:#fff;box-shadow:0 10px 24px -8px #7c5cffd9,inset 0 1px #ffffff59;animation:shimmer 6s var(--ease) infinite alternate}@keyframes shimmer{to{background-position:100% 100%}}.brand-name{font-family:var(--font-display);font-weight:800;font-size:19px;letter-spacing:-.02em}.brand-text{display:flex;flex-direction:column;line-height:1.1}.brand-sub{font-size:11px;color:var(--muted);font-weight:600}.theme-toggle{display:inline-flex;align-items:center;gap:7px;padding:8px 12px;border-radius:10px;border:1px solid var(--border);background:var(--surface-2);color:var(--text);font-size:13px;font-weight:600;cursor:pointer;transition:all .18s var(--ease)}.theme-toggle:hover{background:var(--surface-hover)}.mobile-header-actions{display:flex;align-items:center;gap:8px}.signin-btn{display:inline-flex;align-items:center;gap:8px;padding:9px 13px;border-radius:11px;border:1px solid var(--border-strong);background:var(--surface-2);color:var(--text);font-size:13px;font-weight:600;cursor:pointer;transition:all .18s var(--ease)}.signin-btn:hover{background:var(--surface-hover);border-color:var(--accent)}.signin-btn.compact{padding:8px 10px}.signin-btn.compact span{display:none}.account{position:relative}.account-trigger{display:flex;align-items:center;gap:9px;width:100%;padding:7px 9px;border-radius:12px;border:1px solid var(--border);background:var(--surface-2);color:var(--text);cursor:pointer;transition:background .18s var(--ease)}.account-trigger:hover{background:var(--surface-hover)}.avatar-img{border-radius:50%;object-fit:cover;flex-shrink:0}.avatar-fallback{display:grid;place-items:center;border-radius:50%;background:var(--grad);color:#fff;font-weight:800;font-size:13px;flex-shrink:0}.account-name{flex:1;font-size:13px;font-weight:600;text-align:left;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sync-dot{display:grid;place-items:center;width:20px;height:20px;border-radius:50%;color:var(--green);background:#34d39924;flex-shrink:0}.popover-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:60}.account-menu{position:absolute;z-index:61;bottom:calc(100% + 8px);left:0;right:0;padding:12px;border-radius:14px;background:var(--bg-2);border:1px solid var(--border-strong);box-shadow:var(--shadow);animation:rise .2s var(--ease) both}.account-info{display:flex;align-items:center;gap:10px;padding-bottom:10px;border-bottom:1px solid var(--border)}.account-meta{display:flex;flex-direction:column;min-width:0}.account-meta strong{font-size:14px}.account-meta span{font-size:12px;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.account-note{margin:10px 0;font-size:12px;color:var(--muted)}.account-signout{display:flex;align-items:center;justify-content:center;gap:7px;width:100%;padding:9px;border-radius:10px;border:1px solid var(--border);background:var(--surface-2);color:var(--text);font-size:13px;font-weight:600;cursor:pointer;transition:all .18s var(--ease)}.account-signout:hover{background:#fb6f841f;border-color:#fb6f8459;color:var(--red)}@media(max-width:899px){.account-menu{bottom:auto;top:calc(100% + 8px);left:auto;right:0;width:240px}}.credit-link{font-size:12px;font-weight:600;color:var(--muted);transition:color .18s var(--ease)}.credit-link:hover{color:var(--accent);text-decoration:none}@media(min-width:900px){.app-shell{display:grid;grid-template-columns:264px 1fr}.mobile-header,.mobile-nav{display:none}.sidebar{display:flex;flex-direction:column;position:sticky;top:0;height:100vh;height:100dvh;padding:22px 16px;border-right:1px solid var(--border);background:var(--glass);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px)}.nav{display:flex;flex-direction:column;gap:4px;margin-top:28px;flex:1}.nav-item{display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:12px;border:0;background:none;color:var(--muted);font-size:14px;font-weight:600;cursor:pointer;position:relative;transition:all .18s var(--ease)}.nav-item:hover{background:var(--surface);color:var(--text)}.nav-item.active{background:var(--grad-soft);color:var(--text)}.nav-item.active:before{content:"";position:absolute;left:0;top:22%;bottom:22%;width:3px;border-radius:3px;background:var(--grad)}.nav-badge{margin-left:auto;background:var(--amber);color:#1a1300;font-size:11px;font-weight:800;min-width:20px;height:20px;border-radius:10px;display:grid;place-items:center;padding:0 5px}.sidebar-foot{display:flex;flex-direction:column;gap:12px}.selected-pill{display:inline-flex;align-items:center;gap:7px;font-size:12px;font-weight:600;color:var(--muted);padding:9px 12px;border-radius:10px;background:var(--surface);border:1px solid var(--border)}.credit-link{font-size:11px;color:var(--muted);line-height:1.4}.content{padding:34px 38px 50px}.page-head{flex-direction:row;align-items:flex-end;justify-content:space-between}.page-head .search{width:280px}.word-topic{display:inline-block}.launch-bar{flex-direction:row;align-items:center;justify-content:space-between;padding:12px 18px}.launch-actions{grid-template-columns:repeat(3,auto)}.manage-grid{grid-template-columns:1fr 1fr}.words-panel{grid-column:span 2}.stat-grid{grid-template-columns:repeat(3,1fr)}.stats-lower{grid-template-columns:300px 1fr;align-items:start}.topic-bar-row{grid-template-columns:160px 1fr auto}.app-footer,.review-banner{display:none}}@media(min-width:1100px){.stat-grid{grid-template-columns:repeat(6,1fr)}}@media(pointer:coarse){.icon-btn,.word-actions .icon-btn,.row-actions .icon-btn{width:44px;height:44px}.word-actions{gap:4px}.chip{padding:11px 15px}.seg button{padding:11px 14px}.detail-btn{padding:12px 15px}.launch-btn{padding:13px 12px}.quiz-option{padding:17px 16px}.mnav-item{padding:7px 2px}.toast-close{padding:8px}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.05ms!important}}
