:root{--bg:#fbf9f5;--bg-tint:#f7f1e8;--sidebar:#f3ecdf;--surface:#fff;--surface-2:#f7f2ea;--border:#e7ddcd;--border-strong:#dccdb6;--text:#2a1c14;--text-soft:#4a3228;--muted:#7a6a58;--faint:#a3927d;--accent:#bf4d2b;--accent-hover:#a53f21;--accent-weak:#bf4d2b1a;--accent-ring:#bf4d2b2e;--gold:#c9a96e;--olive:#6f8a52;--success-bg:#6f8a5224;--success-text:#4d6636;--danger:#b23a2e;--radius:14px;--radius-sm:10px;--shadow:0 1px 2px #2a1c140a, 0 8px 24px #2a1c140f}@media (prefers-color-scheme:dark){:root:not([data-theme]){--bg:#1a1410;--bg-tint:#211812;--sidebar:#201711;--surface:#241a14;--surface-2:#2b201a;--border:#3a2c22;--border-strong:#4a3729;--text:#f3ece1;--text-soft:#e2d5c6;--muted:#b6a794;--faint:#8b7c69;--accent:#d4856a;--accent-hover:#e0967c;--accent-weak:#d4856a29;--accent-ring:#d4856a38;--success-bg:#6f8a5233;--success-text:#a8c088;--shadow:0 1px 2px #0000004d, 0 10px 30px #00000059}}:root[data-theme=dark]{--bg:#1a1410;--bg-tint:#211812;--sidebar:#201711;--surface:#241a14;--surface-2:#2b201a;--border:#3a2c22;--border-strong:#4a3729;--text:#f3ece1;--text-soft:#e2d5c6;--muted:#b6a794;--faint:#8b7c69;--accent:#d4856a;--accent-hover:#e0967c;--accent-weak:#d4856a29;--accent-ring:#d4856a38;--success-bg:#6f8a5233;--success-text:#a8c088;--shadow:0 1px 2px #0000004d, 0 10px 30px #00000059}*{box-sizing:border-box}html,body,#root{height:100%}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;line-height:1.5}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}code{background:var(--surface-2);border-radius:5px;padding:.1em .35em;font-size:.85em}.btn{border-radius:var(--radius-sm);cursor:pointer;border:1px solid #0000;justify-content:center;align-items:center;gap:.5rem;padding:.7rem 1rem;font-family:inherit;font-size:.95rem;font-weight:600;transition:background .14s,border-color .14s,transform 50ms;display:inline-flex}.btn:active:not(:disabled){transform:translateY(1px)}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:linear-gradient(180deg, var(--accent), var(--accent-hover));color:#fff;box-shadow:0 1px 2px #9f3f214d}.btn-primary:not(:disabled):hover{background:var(--accent-hover)}.btn-ghost{background:var(--surface);color:var(--text);border-color:var(--border-strong);width:100%}.btn-ghost:not(:disabled):hover{background:var(--surface-2)}.btn-link{color:var(--muted);background:0 0;padding:.35rem;font-weight:500}.btn-link:not(:disabled):hover{color:var(--accent)}.field{flex-direction:column;gap:.4rem;display:flex}.label{color:var(--muted);font-size:.82rem;font-weight:600}.input{width:100%;color:var(--text);background:var(--surface-2);border:1px solid var(--border-strong);border-radius:var(--radius-sm);outline:none;padding:.7rem .8rem;font-family:inherit;font-size:1rem;transition:border-color .14s,box-shadow .14s}.input::placeholder{color:var(--faint)}.input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.code-input{letter-spacing:.5em;text-align:center;font-size:1.15rem;font-weight:600}.stack{flex-direction:column;gap:.85rem;display:flex}.stack-lg{flex-direction:column;gap:1.25rem;max-width:620px;display:flex}.auth-wrap{background:radial-gradient(120% 90% at 50% -10%, var(--bg-tint), var(--bg));place-items:center;min-height:100dvh;padding:1.5rem;display:grid;position:relative;overflow:hidden}.auth-wrap:before,.auth-wrap:after{content:"";filter:blur(90px);z-index:0;pointer-events:none;border-radius:50%;position:absolute}.auth-wrap:before{background:radial-gradient(circle,#bf4d2b47,#0000 68%);width:520px;height:520px;top:-220px;right:-160px}.auth-wrap:after{background:radial-gradient(circle,#c9a96e42,#0000 68%);width:460px;height:460px;bottom:-220px;left:-160px}.auth-card{z-index:1;background:var(--surface);border:1px solid var(--border);width:100%;max-width:400px;box-shadow:var(--shadow);border-radius:20px;padding:2.25rem;position:relative}.auth-brand{align-items:center;gap:.55rem;margin-bottom:1.5rem;display:flex}.auth-brand-name{letter-spacing:-.01em;font-size:1.05rem;font-weight:700}.auth-title{letter-spacing:-.02em;margin:0 0 .25rem;font-size:1.6rem}.auth-subtitle{color:var(--muted);margin:0 0 1.5rem}.auth-foot{z-index:1;margin-top:1.25rem;font-size:.9rem;position:relative}.auth-foot a{color:var(--muted)}.brand-mark{color:#fff;background:linear-gradient(135deg, var(--accent), var(--gold));border-radius:9px;justify-content:center;align-items:center;width:30px;height:30px;display:inline-flex;box-shadow:0 2px 8px #bf4d2b4d}.brand-mark.lg{border-radius:12px;width:40px;height:40px}.divider{color:var(--faint);align-items:center;gap:.75rem;margin:1.25rem 0;font-size:.8rem;display:flex}.divider:before,.divider:after{content:"";background:var(--border);flex:1;height:1px}.notice{color:var(--muted);margin:1rem 0 0;font-size:.9rem}.error{color:var(--danger);margin:1rem 0 0;font-size:.9rem}.banner-warn{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--muted);margin:0 0 1.25rem;padding:.65rem .75rem;font-size:.85rem}.shell{grid-template-columns:260px 1fr;min-height:100dvh;display:grid}.sidebar{background:var(--sidebar);border-right:1px solid var(--border);flex-direction:column;gap:1.25rem;padding:1.15rem .9rem;display:flex}.sidebar-brand{align-items:center;gap:.55rem;padding:.35rem .5rem;display:flex}.brand-name{letter-spacing:-.01em;font-weight:700}.plan-badge{text-transform:uppercase;letter-spacing:.03em;color:var(--muted);background:var(--surface);border:1px solid var(--border);border-radius:999px;margin-left:auto;padding:.12rem .5rem;font-size:.68rem;font-weight:700}.user-block{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);align-items:center;gap:.65rem;padding:.6rem;display:flex}.avatar{color:#fff;background:linear-gradient(135deg, var(--accent), var(--gold));border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:.85rem;font-weight:700;display:inline-flex}.avatar.sm{width:28px;height:28px;font-size:.75rem}.user-meta{flex-direction:column;min-width:0;display:flex}.user-name{white-space:nowrap;text-overflow:ellipsis;font-size:.85rem;font-weight:600;overflow:hidden}.user-sub{color:var(--muted);font-size:.72rem}.nav{flex-direction:column;flex:1;gap:1.1rem;display:flex}.nav-group{flex-direction:column;gap:.15rem;display:flex}.nav-label{text-transform:uppercase;letter-spacing:.06em;color:var(--faint);padding:0 .6rem .35rem;font-size:.68rem;font-weight:700}.nav-item{border-radius:var(--radius-sm);width:100%;color:var(--text-soft);text-align:left;cursor:pointer;background:0 0;border:none;align-items:center;gap:.65rem;padding:.55rem .6rem;font-family:inherit;font-size:.92rem;font-weight:500;transition:background .12s,color .12s;display:flex}.nav-item:disabled{opacity:1}.nav-item:not(.soon):not(.active):hover{background:var(--surface)}.nav-item.active{background:var(--accent-weak);color:var(--accent);box-shadow:inset 2px 0 0 var(--accent);font-weight:600}.nav-item.soon{color:var(--faint);cursor:default}.nav-item-label{flex:1}.soon-badge{text-transform:uppercase;letter-spacing:.03em;color:var(--faint);background:var(--surface);border:1px solid var(--border);border-radius:999px;padding:.08rem .4rem;font-size:.62rem;font-weight:700}.sidebar-foot{flex-direction:column;gap:.75rem;display:flex}.upgrade-cta{color:#fff;border-radius:var(--radius-sm);background:linear-gradient(135deg, var(--accent), var(--gold));cursor:pointer;opacity:.95;border:none;justify-content:center;align-items:center;gap:.5rem;width:100%;padding:.7rem;font-family:inherit;font-size:.9rem;font-weight:700;display:flex}.upgrade-cta:disabled{cursor:default}.foot-links{text-align:center;font-size:.78rem}.foot-links a{color:var(--faint)}.main{flex-direction:column;min-width:0;display:flex}.topbar{border-bottom:1px solid var(--border);background:color-mix(in srgb, var(--bg) 85%, transparent);justify-content:space-between;align-items:center;padding:1rem 1.75rem;display:flex}.topbar-title{letter-spacing:-.01em;margin:0;font-size:1.15rem;font-weight:700}.account-btn{color:var(--muted);background:var(--surface);border:1px solid var(--border);cursor:pointer;border-radius:999px;align-items:center;gap:.4rem;padding:.3rem .5rem .3rem .35rem;display:flex}.account-btn:hover{color:var(--accent);border-color:var(--border-strong)}.content{flex:1;padding:1.75rem}.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.35rem 1.4rem}.panel-head{align-items:center;gap:.85rem;margin-bottom:1.1rem;display:flex}.panel-head>div:not(.panel-icon){flex:1}.panel-icon{width:38px;height:38px;color:var(--accent);background:var(--accent-weak);border-radius:11px;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.panel-title{margin:0;font-size:1.05rem;font-weight:700}.panel-sub{color:var(--muted);margin:.1rem 0 0;font-size:.85rem}.plan-chip{text-transform:uppercase;letter-spacing:.03em;color:var(--text-soft);background:var(--surface-2);border:1px solid var(--border-strong);border-radius:999px;padding:.25rem .7rem;font-size:.72rem;font-weight:700}.detail-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem 1.5rem;margin:0;display:grid}.detail-grid dt{text-transform:uppercase;letter-spacing:.03em;color:var(--faint);margin-bottom:.2rem;font-size:.75rem;font-weight:600}.detail-grid dd{color:var(--text);word-break:break-word;margin:0;font-size:1rem}.info-banner{color:var(--success-text);background:var(--success-bg);border:1px solid color-mix(in srgb, var(--olive) 35%, transparent);border-radius:var(--radius-sm);align-items:flex-start;gap:.6rem;padding:.75rem .85rem;font-size:.9rem;display:flex}.info-banner svg{flex-shrink:0;margin-top:1px}.sign-out{align-self:flex-start;width:auto}@media (width<=860px){.shell{grid-template-columns:72px 1fr}.brand-name,.plan-badge,.user-meta,.nav-label,.nav-item-label,.soon-badge,.foot-links{display:none}.sidebar{align-items:center;padding:1.15rem .5rem}.sidebar-brand,.user-block,.nav-item{justify-content:center}.user-block{padding:.4rem}.upgrade-cta{padding:.7rem 0}.content,.topbar{padding-left:1.1rem;padding-right:1.1rem}}.muted{color:var(--muted)}.center{place-items:center;min-height:100dvh;display:grid}.vocab{max-width:760px}.vocab-toolbar{align-items:center;gap:.85rem;margin-bottom:1.4rem;display:flex}.search{flex:1;min-width:0}.search .input{padding:.6rem .8rem}.vocab-count{color:var(--muted);white-space:nowrap;font-size:.85rem}.vocab-refresh{width:auto;padding:.6rem .85rem}.vocab-group{margin-bottom:1.6rem}.vocab-group-head{border-bottom:1px solid var(--border);align-items:center;gap:.6rem;margin-bottom:.6rem;padding-bottom:.4rem;display:flex}.vocab-group-name{text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin:0;font-size:.78rem;font-weight:700}.vocab-group-count{color:var(--faint);background:var(--surface-2);border:1px solid var(--border);border-radius:999px;padding:.05rem .45rem;font-size:.72rem;font-weight:700}.word-list{flex-direction:column;gap:.4rem;margin:0;padding:0;list-style:none;display:flex}.word-row{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);justify-content:space-between;align-items:baseline;gap:1rem;padding:.7rem .9rem;transition:border-color .12s;display:flex}.word-row:hover{border-color:var(--border-strong)}.word-main{flex-wrap:wrap;align-items:baseline;gap:.5rem;min-width:0;display:flex}.word-text{color:var(--text);font-size:1rem;font-weight:600}.word-tr{color:var(--faint);font-size:.85rem}.pos{text-transform:uppercase;letter-spacing:.03em;color:var(--accent);background:var(--accent-weak);border-radius:999px;padding:.08rem .45rem;font-size:.68rem;font-weight:600}.word-translation{color:var(--text-soft);text-align:right;font-size:.95rem}.state-inline{padding:.5rem 0}.state-msg{text-align:center;flex-direction:column;align-items:center;gap:.9rem;max-width:460px;margin:3rem auto 0;display:flex}.state-msg .panel-title,.state-msg .muted{margin:0}.state-msg .btn{width:auto}.empty-mark{width:60px;height:60px;color:var(--accent);background:var(--accent-weak);border-radius:18px;justify-content:center;align-items:center;display:inline-flex}.spinner{border:2.5px solid var(--border-strong);border-top-color:var(--accent);border-radius:50%;width:22px;height:22px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}@media (width<=560px){.word-row{flex-direction:column;gap:.2rem}.word-translation{text-align:left}}.panel-actions{flex-wrap:wrap;gap:.6rem;margin-top:.4rem;display:flex}.panel-actions .btn{width:auto}.btn-danger-ghost{background:var(--surface);color:var(--danger);border:1px solid color-mix(in srgb, var(--danger) 35%, var(--border))}.btn-danger-ghost:disabled{opacity:.5}.stat-grid{grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.85rem;display:grid}.stat-tile{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);flex-direction:column;gap:.15rem;padding:1.1rem 1.2rem;display:flex}.stat-value{letter-spacing:-.02em;color:var(--text);font-size:1.7rem;font-weight:800}.stat-label{text-transform:uppercase;letter-spacing:.04em;color:var(--muted);font-size:.75rem;font-weight:600}.rank-list{flex-direction:column;gap:.7rem;display:flex}.rank-row{grid-template-columns:90px 1fr 36px;align-items:center;gap:.75rem;display:grid}.rank-name{color:var(--text-soft);font-size:.85rem;font-weight:600}.rank-bar-track{background:var(--surface-2);border-radius:999px;height:10px;overflow:hidden}.rank-bar{border-radius:999px;min-width:2px;height:100%;transition:width .3s}.rank-count{color:var(--muted);text-align:right;font-size:.85rem;font-weight:600}.segmented{background:var(--surface-2);border:1px solid var(--border);border-radius:10px;gap:.25rem;padding:.25rem;display:inline-flex}.segmented-item{color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:7px;padding:.45rem 1.1rem;font-family:inherit;font-size:.9rem;font-weight:600;transition:background .12s,color .12s}.segmented-item:hover{color:var(--text)}.segmented-item.active{color:var(--text);background:var(--surface);box-shadow:var(--shadow)}.upgrade-hero{text-align:center;background:radial-gradient(120% 130% at 50% -20%, var(--accent-weak), var(--surface));flex-direction:column;align-items:center;gap:.5rem;display:flex}.upgrade-hero .brand-mark{margin-bottom:.4rem}.upgrade-hero .btn{width:auto;margin-top:.6rem}.compare{flex-direction:column;display:flex}.compare-head,.compare-row{grid-template-columns:1fr 84px 84px;align-items:center;gap:.5rem;display:grid}.compare-head{border-bottom:1px solid var(--border);margin-bottom:.3rem;padding-bottom:.6rem}.compare-col{text-align:center;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);font-size:.72rem;font-weight:700}.compare-col.pro{color:var(--accent)}.compare-row{border-bottom:1px solid var(--border);padding:.55rem 0}.compare-row:last-child{border-bottom:none}.compare-label{color:var(--text-soft);font-size:.9rem}.compare-cell{text-align:center;color:var(--muted);font-size:.9rem;font-weight:600}.compare-cell.pro{color:var(--text)}.mode-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem;display:grid}.mode-card{text-align:left;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);cursor:pointer;flex-direction:column;gap:.4rem;padding:1.5rem;font-family:inherit;transition:border-color .12s,transform 50ms;display:flex}.mode-card:not(:disabled):hover{border-color:var(--accent)}.mode-card:disabled{opacity:.55;cursor:not-allowed}.mode-icon{width:44px;height:44px;color:var(--accent);background:var(--accent-weak);border-radius:12px;justify-content:center;align-items:center;margin-bottom:.4rem;display:inline-flex}.mode-name{color:var(--text);font-size:1.1rem;font-weight:700}.mode-desc{color:var(--muted);font-size:.88rem}.practice{max-width:620px;margin:0 auto}.practice-bar{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.practice-actions{justify-content:center;gap:.75rem;margin-top:1.25rem;display:flex}.practice-actions .btn{width:auto}.flashcard{border:1px solid var(--border);background:var(--surface);width:100%;min-height:260px;box-shadow:var(--shadow);cursor:pointer;border-radius:20px;flex-direction:column;justify-content:center;align-items:center;gap:.75rem;padding:2rem;font-family:inherit;transition:border-color .12s;display:flex}.flashcard:hover{border-color:var(--border-strong)}.flashcard.flipped{background:radial-gradient(120% 130% at 50% 0%, var(--accent-weak), var(--surface));border-color:color-mix(in srgb, var(--accent) 40%, var(--border))}.flashcard-hint{text-transform:uppercase;letter-spacing:.06em;color:var(--faint);font-size:.72rem;font-weight:600}.flashcard-text{text-align:center;color:var(--text);font-size:2rem;font-weight:700}.quiz-prompt{text-align:center;color:var(--text);background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:16px;margin-bottom:1.1rem;padding:1.75rem;font-size:1.75rem;font-weight:700}.quiz-options{flex-direction:column;gap:.6rem;display:flex}.quiz-option{text-align:left;color:var(--text);background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--radius-sm);cursor:pointer;padding:.85rem 1rem;font-family:inherit;font-size:1rem;font-weight:600;transition:border-color .12s,background .12s}.quiz-option:not(:disabled):hover{border-color:var(--accent)}.quiz-option:disabled{cursor:default}.quiz-option.correct{color:var(--success-text);background:var(--success-bg);border-color:color-mix(in srgb, var(--olive) 45%, transparent)}.quiz-option.wrong{color:var(--danger);background:color-mix(in srgb, var(--danger) 12%, var(--surface));border-color:color-mix(in srgb, var(--danger) 45%, transparent)}
