.app{background:var(--bg);grid-template-columns:240px 1fr 320px;height:100vh;display:grid;overflow:hidden}.app-main{flex-direction:column;min-width:0;display:flex;overflow:hidden}.sidebar{color:#fff;background:#0f172a;flex-direction:column;flex-shrink:0;gap:6px;width:240px;height:100%;padding:16px 12px;display:flex;overflow-y:auto}.sidebar-brand{color:#fff;cursor:pointer;font:inherit;text-align:left;background:0 0;border:none;align-items:center;gap:10px;padding:10px 10px 16px;display:flex}.brand-flag{font-size:1.4rem;line-height:1}.brand-name{letter-spacing:-.02em;font-size:.95rem;font-weight:800;line-height:1.3}.sidebar-nav{flex-direction:column;flex:1;gap:2px;display:flex}.nav-item{border-radius:var(--r-md);color:#fff9;width:100%;font:inherit;cursor:pointer;text-align:left;transition:background var(--t), color var(--t);background:0 0;border:none;align-items:center;gap:10px;padding:9px 12px;font-size:.85rem;font-weight:500;display:flex}.nav-item:hover{color:#ffffffe6;background:#ffffff14}.nav-item.active{color:#fff;border-left:3px solid var(--accent);background:#4f46e52e;padding-left:9px}.nav-icon-svg{opacity:.85;flex-shrink:0}.nav-item.active .nav-icon-svg{opacity:1}.nav-label{flex:1}.nav-badge{border-radius:var(--r-full);color:#fff;text-align:center;background:#ef4444;flex-shrink:0;min-width:20px;padding:1px 6px;font-size:.68rem;font-weight:800;animation:2s infinite badge-pulse}@keyframes badge-pulse{0%,to{box-shadow:0 0 #ef444466}50%{box-shadow:0 0 0 4px #ef444400}}.sidebar-foot{flex-direction:column;gap:8px;padding-top:8px;display:flex}.sidebar-user{border-radius:var(--r-md);color:#ffffffb3;width:100%;font:inherit;cursor:pointer;text-align:left;transition:background var(--t), color var(--t);background:0 0;border:1px solid #ffffff1a;align-items:center;gap:10px;padding:9px 10px;font-size:.82rem;font-weight:500;display:flex}.sidebar-user:hover{color:#fff;background:#ffffff14}.sidebar-user-name{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.side-level{border-radius:var(--r-lg);color:#fff;width:100%;font:inherit;cursor:pointer;text-align:left;transition:background var(--t);background:#ffffff0f;border:1px solid #ffffff1a;flex-direction:column;gap:8px;padding:12px;display:flex}.side-level:hover{background:#ffffff1a}.side-level-top{justify-content:space-between;align-items:center;display:flex}.side-level-badge{border-radius:var(--r-full);background:var(--accent);color:#fff;padding:2px 8px;font-size:.72rem;font-weight:800}.side-level-streak{color:#ffffffd9;align-items:center;font-size:.78rem;font-weight:700;display:flex}.side-level-track{border-radius:var(--r-full);background:#00000059;height:6px;overflow:hidden}.side-level-fill{border-radius:var(--r-full);background:linear-gradient(90deg, var(--accent), #818cf8);height:100%;transition:width .6s cubic-bezier(.22,1,.36,1)}.side-level-foot{align-items:center;gap:4px;display:flex}.side-level-xp{opacity:.8;font-size:.72rem;font-weight:700}.levelbar-flash{color:#818cf8;margin-left:4px;font-size:.7rem;font-weight:800;animation:1.2s ease-out forwards xp-pop}@keyframes xp-pop{0%{opacity:0;transform:translateY(4px)scale(.8)}20%{opacity:1;transform:translateY(0)scale(1.1)}to{opacity:0;transform:translateY(-8px)scale(1)}}.sidebar-backdrop{z-index:30;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0f172a80;display:none;position:fixed;inset:0}.topbar{border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0;align-items:center;gap:10px;padding:12px 18px;display:flex}.topbar-menu{border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface-2);width:36px;height:36px;color:var(--text-1);cursor:pointer;flex-shrink:0;justify-content:center;align-items:center;display:none}.topbar-titles{flex:1;min-width:0}.topbar-titles h1{letter-spacing:-.02em;color:var(--text-1);margin:0;font-size:1rem;font-weight:800}.subtitle{color:var(--text-3);margin:1px 0 0;font-size:.75rem;font-weight:500}.topbar-btn{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-md);width:36px;height:36px;color:var(--text-2);cursor:pointer;transition:background var(--t), border-color var(--t), color var(--t);flex-shrink:0;justify-content:center;align-items:center;display:flex}.topbar-btn:hover{background:var(--surface-3);border-color:var(--border-2);color:var(--text-1)}.topbar-signout{text-overflow:ellipsis;white-space:nowrap;max-width:100px;padding:0 10px;font-size:12px;font-weight:600;overflow:hidden}.avatar-wrap{position:relative}.avatar-trigger{cursor:pointer;transition:border-color var(--t);background:0 0;border:1.5px solid #0000;border-radius:50%;justify-content:center;align-items:center;padding:2px;display:flex}.avatar-trigger:hover{border-color:var(--accent)}.avatar-menu{z-index:21;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);width:240px;box-shadow:var(--shadow-xl);position:absolute;top:calc(100% + 10px);right:0;overflow:hidden}.avatar-menu-header{align-items:center;gap:12px;padding:16px;display:flex}.avatar-menu-info{flex-direction:column;gap:2px;min-width:0;display:flex}.avatar-menu-name{color:var(--text-1);text-overflow:ellipsis;white-space:nowrap;font-size:13px;font-weight:700;overflow:hidden}.avatar-menu-email{color:var(--text-3);text-overflow:ellipsis;white-space:nowrap;font-size:11px;overflow:hidden}.avatar-menu-divider{background:var(--border);height:1px;margin:0}.avatar-menu-item{width:100%;font:inherit;color:var(--text-2);cursor:pointer;text-align:left;transition:background var(--t), color var(--t);background:0 0;border:none;align-items:center;gap:10px;padding:11px 16px;font-size:13px;font-weight:500;display:flex}.avatar-menu-item:hover{background:var(--surface-2);color:var(--text-1)}.avatar-menu-item-danger:hover{background:var(--danger-light);color:var(--danger)}.settings-wrap{position:relative}.settings-backdrop{z-index:20;position:fixed;inset:0}.settings-panel{z-index:21;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);width:220px;box-shadow:var(--shadow-xl);flex-direction:column;gap:12px;padding:14px;display:flex;position:absolute;top:calc(100% + 10px);right:0}.settings-panel label{text-transform:uppercase;letter-spacing:.07em;color:var(--text-3);flex-direction:column;gap:5px;font-size:.65rem;font-weight:700;display:flex}.settings-panel select{font:inherit;text-transform:none;letter-spacing:normal;color:var(--text-1);border:1.5px solid var(--border);border-radius:var(--r-md);background:var(--surface);cursor:pointer;transition:border-color var(--t), box-shadow var(--t);outline:none;padding:8px 10px;font-size:.88rem;font-weight:500}.settings-panel select:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-muted)}.right-rail{border-left:1px solid var(--border);background:var(--surface-2);flex-direction:column;gap:14px;padding:20px 16px;display:flex;overflow-y:auto}.right-rail::-webkit-scrollbar{width:4px}.right-rail::-webkit-scrollbar-thumb{background:var(--border-2);border-radius:var(--r-full)}.rail-card{background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow-xs);border-radius:14px;flex-direction:column;gap:12px;padding:16px;display:flex}.rail-card-title{text-transform:uppercase;letter-spacing:.07em;color:var(--text-3);align-items:center;gap:6px;font-size:.68rem;font-weight:700;display:flex}.rail-level-row{justify-content:space-between;align-items:center;gap:8px;display:flex}.rail-level-left{align-items:center;gap:8px;display:flex}.rail-level-badge{color:var(--text-1);font-size:.88rem;font-weight:800}.rail-level-cefr{border-radius:var(--r-full);background:var(--primary-light);color:var(--primary);letter-spacing:.05em;padding:2px 8px;font-size:.65rem;font-weight:800;display:inline-block}.rail-xp-pill{color:var(--text-2);align-items:center;gap:4px;font-size:.72rem;font-weight:700;display:flex}.rail-bar-track{border-radius:var(--r-full);background:var(--surface-3);height:8px;overflow:hidden}.rail-bar-fill{border-radius:var(--r-full);background:linear-gradient(90deg, var(--accent), #818cf8);height:100%;transition:width .7s cubic-bezier(.22,1,.36,1)}.rail-bar-meta{color:var(--text-3);justify-content:space-between;font-size:.67rem;display:flex}.rail-streak-pill{color:var(--text-2);border-radius:var(--r-full);background:#fb923c1a;border:1px solid #fb923c33;align-items:center;gap:5px;padding:5px 12px;font-size:.82rem;display:flex}.rail-streak-pill strong{color:#fb923c;font-size:.95rem;font-weight:900}.rail-streak-best{color:var(--text-3);margin-left:auto;font-size:.68rem}.rail-goal-row{color:var(--text-2);align-items:center;gap:6px;font-size:.85rem;font-weight:600;display:flex}.rail-goal-track{border-radius:var(--r-full);background:var(--surface-3);height:8px;overflow:hidden}.rail-goal-fill{border-radius:var(--r-full);background:linear-gradient(90deg, var(--accent), #818cf8);height:100%;transition:width .7s cubic-bezier(.22,1,.36,1)}.rail-goal-pct{color:var(--text-3);font-size:.72rem}.rail-empty{color:var(--text-3);text-align:center;margin:0;padding:8px 0;font-size:.82rem}.rail-review-list{flex-direction:column;gap:6px;margin:0;padding:0;list-style:none;display:flex}.rail-review-item{background:var(--surface-2);border-radius:var(--r-md);border:1px solid var(--border);flex-direction:column;gap:1px;padding:8px 10px;display:flex}.rail-review-word{color:var(--text-1);font-size:.88rem;font-weight:600}.rail-review-hint{color:var(--text-3);text-overflow:ellipsis;white-space:nowrap;font-size:.75rem;overflow:hidden}.rail-review-btn{border-radius:var(--r-md);background:var(--primary-light);width:100%;color:var(--primary);font:inherit;cursor:pointer;transition:background var(--t);border:none;justify-content:center;align-items:center;gap:6px;padding:9px 14px;font-size:.82rem;font-weight:700;display:flex}.rail-review-btn:hover{background:var(--primary-muted)}.chat{scroll-behavior:smooth;flex-direction:column;flex:1;gap:16px;padding:20px 16px;display:flex;overflow-y:auto}.chat::-webkit-scrollbar{width:4px}.chat::-webkit-scrollbar-track{background:0 0}.chat::-webkit-scrollbar-thumb{background:var(--border-2);border-radius:var(--r-full)}.empty{text-align:center;color:var(--text-3);margin:auto;padding:32px 16px}.empty-hint{margin-top:8px;font-size:.84rem;line-height:1.6}.row{display:flex}.row-user{justify-content:flex-end}.row-assistant{justify-content:flex-start}.bubble{word-wrap:break-word;border-radius:18px;max-width:80%;padding:11px 16px;font-size:.93rem;line-height:1.55}.bubble-user{background:var(--accent);color:#fff;border-bottom-right-radius:4px;box-shadow:0 2px 10px #4f46e540}.bubble-assistant{background:var(--surface-2);color:var(--text-1);border:1px solid var(--border);box-shadow:var(--shadow-xs);border-bottom-left-radius:4px;position:relative}.assistant-stack{flex-direction:column;gap:8px;max-width:88%;display:flex}.bubble-label,.card-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-3);margin-bottom:5px;font-size:.63rem;font-weight:700;display:block}.reply-text{margin:0;padding-right:28px}.card{border-radius:var(--r-lg);padding:12px 16px;font-size:.9rem;line-height:1.55}.card p{margin:0}.card-correction{border-left:3px solid var(--amber-400);color:#78350f;background:#fffbeb}.correction-list{margin:0;padding-left:18px}.correction-list li{margin:4px 0;line-height:1.55}.card-better{background:var(--primary-light);border-left:3px solid var(--primary);color:var(--accent-hover)}.card-better-head{justify-content:space-between;align-items:center;gap:8px;margin-bottom:4px;display:flex}.speaker-btn{cursor:pointer;border-radius:var(--r-sm);color:var(--text-3);transition:background var(--t), color var(--t);background:0 0;border:none;justify-content:center;align-items:center;padding:4px 6px;font-size:.92rem;display:inline-flex}.speaker-btn:hover{color:var(--text-1);background:#00000012}.speaker-inline{position:absolute;bottom:7px;right:8px}.typing{align-items:center;gap:5px;padding:12px 16px;display:flex}.typing span{background:var(--text-3);border-radius:50%;width:7px;height:7px;animation:1.4s infinite dot-bounce}.typing span:nth-child(2){animation-delay:.2s}.typing span:nth-child(3){animation-delay:.4s}@keyframes dot-bounce{0%,80%,to{opacity:.4;transform:scale(.7)}40%{opacity:1;transform:scale(1)}}.error-banner{background:var(--danger-light);color:#9f1239;border-top:1px solid var(--danger-border);flex-shrink:0;padding:12px 20px;font-size:.84rem;font-weight:500;line-height:1.5}.composer{border-top:1px solid var(--border);background:var(--surface);flex-shrink:0;align-items:center;gap:8px;padding:12px 16px;display:flex}.text-input{background:var(--surface-2);border:1.5px solid var(--border);border-radius:var(--r-full);min-width:0;font:inherit;color:var(--text-1);transition:border-color var(--t), box-shadow var(--t), background var(--t);outline:none;flex:1;padding:10px 16px;font-size:.93rem}.text-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-muted);background:var(--surface)}.text-input::placeholder{color:var(--text-3)}.text-input:disabled{opacity:.6;cursor:not-allowed}.mic-btn{border-radius:var(--r-full);background:var(--surface-3);cursor:pointer;width:42px;height:42px;transition:background var(--t);border:none;flex-shrink:0;justify-content:center;align-items:center;font-size:1.1rem;display:flex}.mic-btn:hover{background:var(--border)}.mic-btn.mic-on{color:var(--danger);background:#fee2e2;animation:1.2s infinite mic-pulse}@keyframes mic-pulse{0%,to{box-shadow:0 0 #f43f5e66}50%{box-shadow:0 0 0 8px #f43f5e00}}.send-btn{background:var(--primary);color:#fff;border-radius:var(--r-full);font:inherit;cursor:pointer;white-space:nowrap;transition:background var(--t), box-shadow var(--t), transform var(--t);border:none;justify-content:center;align-items:center;gap:6px;padding:10px 20px;font-size:.88rem;font-weight:600;display:inline-flex;box-shadow:0 2px 10px #4f46e540}.send-btn:hover:not(:disabled){background:var(--primary-dark);box-shadow:0 4px 16px #4f46e559}.send-btn:active:not(:disabled){transform:scale(.97)}.send-btn:disabled{background:var(--border-2);color:var(--text-3);cursor:not-allowed;box-shadow:none}.link-btn{color:var(--primary);font:inherit;cursor:pointer;border-radius:var(--r-md);transition:background var(--t);background:0 0;border:none;align-items:center;padding:4px 8px;font-size:.84rem;font-weight:600;display:inline-flex}.link-btn:hover{background:var(--primary-light)}.link-btn:disabled{opacity:.5;cursor:not-allowed}.modal-overlay{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:50;background:#0f172aa6;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal{background:var(--surface);border-radius:var(--r-2xl);width:100%;max-width:390px;box-shadow:var(--shadow-xl);flex-direction:column;gap:16px;padding:28px;display:flex}.modal h2{color:var(--text-1);letter-spacing:-.01em;margin:0;font-size:1.15rem;font-weight:800}.modal-text{color:var(--text-2);margin:0;font-size:.88rem;line-height:1.6}.setup-wrap{align-items:center}.home{width:100%;max-width:800px;margin:auto;padding:8px 0 24px}.home-heading{color:var(--text-2);letter-spacing:-.01em;margin:0 0 16px;font-size:1rem;font-weight:700}.home-grid{grid-template-columns:repeat(2,1fr);gap:12px;display:grid}.home-card{background:var(--surface);border:1.5px solid var(--border);cursor:pointer;font:inherit;text-align:left;transition:border-color var(--t), transform var(--t-spring), box-shadow var(--t);border-radius:16px;flex-direction:row;align-items:center;gap:14px;padding:16px 18px;display:flex}.home-card:hover{box-shadow:0 6px 20px #4f46e514, var(--shadow-md);border-color:#4f46e54d;transform:translateY(-2px)}.home-card:active{transform:translateY(0)}.home-icon{border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:46px;height:46px;display:flex}.home-card-body{flex-direction:column;gap:3px;min-width:0;display:flex}.home-card-title{color:var(--text-1);align-items:center;gap:6px;font-size:.88rem;font-weight:700;line-height:1.35;display:flex}.home-card-badge{border-radius:var(--r-full);color:#fff;background:#ef4444;justify-content:center;align-items:center;min-width:18px;height:18px;padding:0 5px;font-size:.65rem;font-weight:800;display:inline-flex}.home-card-desc{color:var(--text-3);font-size:.73rem;line-height:1.4}.home-card-tags{flex-wrap:wrap;gap:4px;margin-top:4px;display:flex}.home-card-tag{color:var(--primary);opacity:.75;font-size:.65rem;font-weight:600}.setup{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-xl);width:100%;max-width:460px;box-shadow:var(--shadow-sm);flex-direction:column;gap:16px;margin:auto;padding:24px;display:flex}.setup-title{color:var(--text-1);letter-spacing:-.01em;margin:0;font-size:1rem;font-weight:700}.setup-field{text-transform:uppercase;letter-spacing:.08em;color:var(--text-3);flex-direction:column;gap:6px;font-size:.65rem;font-weight:700;display:flex}.setup-field input,.setup-field select,.setup-field textarea{font:inherit;text-transform:none;letter-spacing:normal;color:var(--text-1);border:1.5px solid var(--border);border-radius:var(--r-md);background:var(--surface);transition:border-color var(--t), box-shadow var(--t);outline:none;padding:10px 12px;font-size:.92rem;font-weight:400}.setup-field textarea{resize:vertical;line-height:1.55}.setup-field input:focus,.setup-field select:focus,.setup-field textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-muted)}.setup-row{gap:12px;display:flex}.setup-row .setup-field{flex:1}.setup-start{margin-top:4px}.setup-error{border-radius:var(--r-lg);border-top:none;width:100%;max-width:460px;margin-top:12px}.interview-bar{color:var(--text-2);background:var(--primary-light);border-radius:var(--r-lg);border:1px solid #4f46e533;justify-content:space-between;align-items:center;gap:12px;padding:8px 14px;font-size:.82rem;font-weight:500;display:flex}.subtab-toggle{background:var(--surface-3);border:1.5px solid var(--border);border-radius:var(--r-full);align-self:center;gap:3px;margin-bottom:16px;padding:3px;display:flex}.subtab{font:inherit;color:var(--text-2);cursor:pointer;border-radius:var(--r-full);transition:background var(--t), color var(--t), box-shadow var(--t);background:0 0;border:none;padding:6px 18px;font-size:.82rem;font-weight:600}.subtab:hover:not(.active){background:var(--border)}.subtab.active{background:var(--primary);color:#fff;box-shadow:0 2px 8px #4f46e54d}.review{flex-direction:column;gap:16px;width:100%;max-width:500px;margin:auto;display:flex}.review-head{justify-content:space-between;align-items:center;gap:12px;display:flex}.review-count{color:var(--text-3);background:var(--surface-3);border-radius:var(--r-full);flex-shrink:0;padding:3px 10px;font-size:.75rem;font-weight:600}.review-empty{text-align:center;color:var(--text-2);margin:32px 0;font-size:.9rem;line-height:1.7}.card-review{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-xl);box-shadow:var(--shadow-sm);flex-direction:column;gap:12px;padding:22px;display:flex}.review-original{color:var(--text-1);margin:0;font-size:1rem;font-weight:500;line-height:1.55}.review-hint{color:var(--text-2);margin:0;font-size:.88rem;line-height:1.6}.review-input{font:inherit;color:var(--text-1);border:1.5px solid var(--border);border-radius:var(--r-md);resize:vertical;background:var(--surface-2);transition:border-color var(--t), box-shadow var(--t), background var(--t);outline:none;padding:10px 13px;font-size:.93rem;line-height:1.5}.review-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-muted);background:var(--surface)}.review-answer,.review-reveal{margin-top:4px}.review-actions{gap:10px;margin-top:4px;display:flex}.grade-btn{cursor:pointer;font:inherit;border-radius:var(--r-full);transition:background var(--t), transform var(--t);border:none;flex:1;padding:12px 16px;font-size:.9rem;font-weight:700}.grade-btn:active{transform:scale(.97)}.grade-again{color:#9f1239;background:#fee2e2}.grade-again:hover{background:#fecdd3}.grade-good{background:var(--primary);color:#fff}.grade-good:hover{background:var(--primary-dark)}.grade-suggested{outline-offset:2px;outline:3px solid #e85d4a66}.wl-list{flex-direction:column;gap:6px;margin-top:4px;display:flex}.wl-row{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-md);transition:background var(--t);justify-content:space-between;align-items:center;gap:10px;padding:10px 14px;display:flex}.wl-row:hover{background:var(--surface-3)}.wl-text{flex-direction:column;min-width:0;display:flex}.wl-front{color:var(--text-1);font-size:.9rem;font-weight:600}.wl-meaning{color:var(--text-3);text-overflow:ellipsis;white-space:nowrap;margin-top:1px;font-size:.77rem;overflow:hidden}.wl-del{cursor:pointer;border-radius:var(--r-md);color:var(--text-3);transition:background var(--t), color var(--t);background:0 0;border:none;flex-shrink:0;padding:4px 8px;font-size:1rem}.wl-del:hover{color:var(--danger);background:#fee2e2}.verdict{border-radius:var(--r-lg);flex-direction:column;gap:4px;padding:12px 16px;font-size:.88rem;line-height:1.5;display:flex}.verdict strong{font-size:.93rem}.verdict-good{background:var(--success-light);color:#065f46;border:1px solid var(--success-border)}.verdict-bad{background:var(--danger-light);color:#9f1239;border:1px solid var(--danger-border)}.listen-controls{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.dict-search{gap:8px;display:flex}.dict-search .review-input{flex:1}.dict-headword{justify-content:space-between;align-items:center;gap:12px;display:flex}.dict-word{color:var(--text-1);letter-spacing:-.02em;font-size:1.4rem;font-weight:800}.dict-meta{color:var(--text-3);margin:1px 0 4px;font-size:.8rem;font-style:italic}.dict-example{background:var(--surface-3);border-radius:var(--r-md);color:var(--text-1);justify-content:space-between;align-items:center;gap:8px;padding:10px 14px;font-size:.9rem;line-height:1.55;display:flex}.drill-type{background:var(--surface);color:var(--text-1);border:1.5px solid var(--border);border-radius:var(--r-full);font:inherit;cursor:pointer;transition:border-color var(--t);outline:none;padding:6px 14px;font-size:.82rem;font-weight:600}.drill-type:focus{border-color:var(--primary)}.game-toggle{color:var(--text-2);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:8px;font-size:.84rem;display:flex}.drill-target{color:var(--text-1);letter-spacing:-.01em;margin:0 0 4px;font-size:1.3rem;font-weight:800;line-height:1.3}.drill-gloss{color:var(--text-3);font-size:.9rem;font-weight:400}.conj-pron{color:var(--primary);font-weight:800}.conj-tense{border-radius:var(--r-full);background:var(--primary-light);color:var(--primary-dark);letter-spacing:.05em;text-transform:uppercase;margin:0 0 4px;padding:3px 12px;font-size:.7rem;font-weight:800;display:inline-block}.cloze-sentence{font-size:1.08rem;font-weight:500;line-height:1.75}.cloze-blank{text-align:center;border-bottom:2px dashed var(--border-2);min-width:80px;color:var(--text-3);margin:0 3px;padding:0 10px;font-weight:700;display:inline-block}.cloze-blank-filled{border-bottom-color:var(--success);color:#065f46}.sb-answer{border:2px dashed var(--border-2);border-radius:var(--r-lg);background:var(--surface-2);min-height:56px;transition:border-color var(--t), background var(--t);flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:12px;padding:10px 14px;display:flex}.sb-answer-correct{border-style:solid;border-color:var(--success);background:var(--success-light)}.sb-answer-wrong{border-style:solid;border-color:var(--danger);background:var(--danger-light)}.sb-placeholder{color:var(--text-3);font-size:.95rem}.sb-pool{flex-wrap:wrap;gap:8px;margin-bottom:8px;display:flex}.sb-tile{font:inherit;border-radius:var(--r-full);background:var(--primary-light);color:var(--primary-dark);cursor:grab;-webkit-user-select:none;user-select:none;transition:transform var(--t), background var(--t), box-shadow var(--t);border:1.5px solid #4f46e533;padding:7px 14px;font-size:.88rem;font-weight:600}.sb-tile:active{cursor:grabbing}.sb-tile:hover{box-shadow:var(--shadow-sm);background:#4f46e526;transform:translateY(-2px)}.sb-caret{background:var(--primary);border-radius:2px;align-self:stretch;width:2px;min-height:26px;animation:.8s steps(2,start) infinite caret-blink;display:inline-block}@keyframes caret-blink{to{opacity:.2}}.sb-tile-picked{background:var(--primary);color:#fff;border-color:#0000}.sb-tile-picked:hover{background:var(--primary-dark);box-shadow:var(--shadow-sm)}.sb-actions{justify-content:space-between;align-items:center;gap:12px;margin-top:4px;display:flex}.related{gap:10px;margin-top:4px;display:flex}.related-col{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-md);flex:1;padding:10px 14px}.related-col p{color:var(--text-1);margin:3px 0;font-size:.9rem}.game-stats{color:var(--text-2);margin:0;font-size:.82rem;font-weight:600}.choices{flex-direction:column;gap:8px;margin-top:6px;display:flex}.choices-row{flex-direction:row}.choice{border:1.5px solid var(--border);background:var(--surface);color:var(--text-1);border-radius:var(--r-lg);font:inherit;cursor:pointer;text-align:left;transition:border-color var(--t), background var(--t), transform var(--t);flex:1;padding:12px 16px;font-size:.9rem;font-weight:500}.choice:hover:not(:disabled){border-color:var(--primary);background:var(--primary-light);transform:translateY(-1px)}.choice:disabled{cursor:default}.choices-row .choice{text-align:center;padding:14px;font-size:1.15rem;font-weight:700}.choice-correct{background:var(--success-light)!important;border-color:var(--success-border)!important;color:#065f46!important}.choice-wrong{background:var(--danger-light)!important;border-color:var(--danger-border)!important;color:#9f1239!important}.gender-btn{font-size:1.2rem}.gender-btn.g-der{color:#2563eb;background:#eff6ff;border-color:#bfdbfe}.gender-btn.g-die{color:#dc2626;background:#fff1f2;border-color:#fecaca}.gender-btn.g-das{color:#16a34a;background:#f0fdf4;border-color:#bbf7d0}.match-grid{gap:10px;margin-top:8px;display:flex}.match-col{flex-direction:column;flex:1;gap:8px;display:flex}.match-tile{border:1.5px solid var(--border);background:var(--surface);color:var(--text-1);border-radius:var(--r-md);font:inherit;cursor:pointer;text-align:center;transition:border-color var(--t), background var(--t);padding:10px 12px;font-size:.88rem;font-weight:500}.match-tile:hover:not(:disabled){border-color:var(--primary);background:var(--primary-light)}.tile-sel{font-weight:700;background:var(--primary-light)!important;border-color:var(--primary)!important}.tile-done{cursor:default;background:var(--success-light)!important;border-color:var(--success-border)!important;color:#065f46!important}.tile-wrong{background:var(--danger-light)!important;border-color:var(--danger-border)!important}.lw{cursor:pointer;transition:background var(--t);border-radius:3px}.lw:hover{background:#4f46e51a}.lw-active{background:#4f46e52e;box-shadow:0 0 0 1px #4f46e559}.row,.card-review,.home-card,.interview-bar{animation:.28s cubic-bezier(.22,1,.36,1) both rise}@keyframes rise{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.home-card:nth-child(2){animation-delay:30ms}.home-card:nth-child(3){animation-delay:60ms}.home-card:nth-child(4){animation-delay:90ms}.home-card:nth-child(5){animation-delay:.12s}.home-card:nth-child(6){animation-delay:.15s}.home-card:nth-child(7){animation-delay:.18s}.home-card:nth-child(8){animation-delay:.21s}.home-card:nth-child(9){animation-delay:.24s}.home-card:nth-child(10){animation-delay:.27s}button:focus-visible,select:focus-visible,input:focus-visible,textarea:focus-visible,.nav-item:focus-visible{outline:2px solid var(--primary);outline-offset:2px}[data-theme=dark] .card-correction{color:#fcd34d;background:#fbbf241a}[data-theme=dark] .card-better{color:#818cf8;background:#4f46e524}[data-theme=dark] .verdict-good{color:#6ee7b7}[data-theme=dark] .verdict-bad{color:#fda4af}[data-theme=dark] .choice-correct{color:#6ee7b7!important}[data-theme=dark] .choice-wrong{color:#fda4af!important}[data-theme=dark] .tile-done{color:#6ee7b7!important}[data-theme=dark] .grade-again{color:#fda4af;background:#f43f5e29}[data-theme=dark] .grade-again:hover{background:#f43f5e3d}[data-theme=dark] .error-banner{color:#fda4af}[data-theme=dark] .sb-tile,[data-theme=dark] .conj-tense{color:#818cf8}[data-theme=dark] .cloze-blank-filled{color:#6ee7b7}[data-theme=dark] .gender-btn.g-der{color:#93c5fd;background:#2563eb29;border-color:#2563eb66}[data-theme=dark] .gender-btn.g-die{color:#fca5a5;background:#dc262629;border-color:#dc262666}[data-theme=dark] .gender-btn.g-das{color:#86efac;background:#16a34a29;border-color:#16a34a66}[data-theme=dark] .lw:hover{background:#4f46e52e}[data-theme=dark] .lw-active{background:#4f46e547;box-shadow:0 0 0 1px #4f46e580}@media (width<=1200px){.app{grid-template-columns:240px 1fr}.right-rail{display:none}}@media (width<=900px){.app{grid-template-columns:1fr}.sidebar{z-index:40;height:100vh;box-shadow:var(--shadow-xl);transition:transform .26s cubic-bezier(.22,1,.36,1);position:fixed;top:0;left:0;transform:translate(-100%)}.sidebar.open{transform:translate(0)}.sidebar-backdrop{display:block}.topbar-menu{display:flex}}@media (width<=480px){.bubble,.assistant-stack{max-width:94%}.home-grid{grid-template-columns:1fr;gap:8px}.send-btn{padding:10px 14px}.review{max-width:100%}}.auth-overlay{z-index:1000;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#00000080;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.auth-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);width:100%;max-width:400px;box-shadow:var(--shadow-xl);flex-direction:column;gap:20px;padding:36px 32px 32px;display:flex;position:relative;overflow:hidden}.auth-card:before{content:"";background:linear-gradient(90deg, var(--accent), #818cf8);height:3px;position:absolute;top:0;left:0;right:0}.auth-logo{font-family:var(--font-display);color:var(--accent);letter-spacing:-.02em;text-align:center;font-size:16px;font-weight:800}.auth-tabs{background:var(--surface-2);border-radius:var(--r-full);gap:3px;padding:3px;display:flex}.auth-tab{border-radius:var(--r-full);font:inherit;cursor:pointer;color:var(--text-secondary);transition:background var(--t), color var(--t), box-shadow var(--t);background:0 0;border:none;flex:1;padding:8px 12px;font-size:13px;font-weight:600}.auth-tab.active{background:var(--surface);color:var(--text-primary);box-shadow:0 1px 4px #0000001a}.auth-google-btn{justify-content:center;width:100%;display:flex}.auth-google-btn>div,.auth-google-btn iframe{width:100%!important}.auth-divider{color:var(--text-tertiary);align-items:center;gap:10px;margin:-4px 0;font-size:12px;display:flex}.auth-divider:before,.auth-divider:after{content:"";background:var(--border);flex:1;height:1px}.auth-form{flex-direction:column;gap:10px;display:flex}.auth-input{border:1.5px solid var(--border);border-radius:var(--r-md);font:inherit;background:var(--surface-2);color:var(--text-primary);transition:border-color var(--t), box-shadow var(--t);outline:none;width:100%;padding:11px 14px;font-size:14px}.auth-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.auth-input::placeholder{color:var(--text-tertiary)}.auth-input-code{letter-spacing:12px;text-align:center;padding:16px;font-size:28px;font-weight:800}.auth-error{color:var(--error);margin:2px 0 0;font-size:13px}.auth-btn{background:var(--accent);color:#fff;border-radius:var(--r-md);font:inherit;cursor:pointer;transition:background var(--t), box-shadow var(--t), opacity var(--t);border:none;justify-content:center;align-items:center;gap:8px;min-height:44px;margin-top:4px;padding:12px;font-size:14px;font-weight:600;display:flex;box-shadow:0 2px 10px #4f46e540}.auth-btn:hover:not(:disabled){background:var(--accent-hover);box-shadow:0 4px 16px #4f46e559}.auth-btn:disabled{opacity:.5;cursor:not-allowed}.auth-verify-section{flex-direction:column;gap:14px;display:flex}.auth-verify-title{color:var(--text-primary);text-align:center;margin:0;font-size:20px;font-weight:700}.auth-verify-sub{color:var(--text-secondary);text-align:center;margin:0;font-size:14px;line-height:1.55}.auth-link-btn{color:var(--text-secondary);font:inherit;cursor:pointer;text-align:center;transition:color var(--t);background:0 0;border:none;padding:4px 0;font-size:13px;text-decoration:underline}.auth-link-btn:hover:not(:disabled){color:var(--accent)}.auth-link-btn:disabled{opacity:.5;cursor:not-allowed}.spinner{border:2px solid #ffffff4d;border-top-color:currentColor;border-radius:50%;flex-shrink:0;animation:.7s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.landing{background:var(--bg-primary);min-height:100vh;color:var(--text-primary);font-family:var(--font-sans)}.lp-nav{z-index:100;align-items:center;gap:var(--space-6);padding:0 var(--space-8);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);background:#ffffffe6;height:64px;display:flex;position:sticky;top:0}[data-theme=dark] .lp-nav{background:#0f0f14e6}.lp-wordmark{font-family:var(--font-display);font-size:var(--text-base);color:var(--text-primary);letter-spacing:-.02em;flex-shrink:0;font-weight:800}.lp-links{gap:var(--space-5);flex:1;display:flex}.lp-link{font-size:var(--text-sm);color:var(--text-secondary);transition:color var(--transition);font-weight:500;text-decoration:none}.lp-link:hover{color:var(--text-primary)}.lp-btn-outline{border:1.5px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font:inherit;font-size:var(--text-sm);cursor:pointer;transition:border-color var(--transition), color var(--transition);background:0 0;padding:8px 18px;font-weight:600}.lp-btn-outline:hover{border-color:var(--accent);color:var(--accent)}.lp-btn-primary{background:var(--accent);color:#fff;border-radius:var(--radius-sm);font:inherit;font-size:var(--text-base);cursor:pointer;transition:background var(--transition), transform var(--transition), box-shadow var(--transition);border:none;align-items:center;padding:12px 26px;font-weight:600;display:inline-flex;box-shadow:0 2px 12px #4f46e54d}.lp-btn-primary:hover{background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 4px 20px #4f46e566}.lp-btn-primary:active{box-shadow:none;transform:scale(.98)}.lp-btn-primary.lp-btn-lg{font-size:var(--text-md);padding:14px 32px}.lp-hero{padding:96px var(--space-8) 80px;text-align:center;position:relative;overflow:hidden}.lp-hero:before{content:"";z-index:0;pointer-events:none;background:radial-gradient(70% 50% at 50% 0,#4f46e51a 0%,#0000 70%);position:absolute;inset:0}[data-theme=dark] .lp-hero:before{background:radial-gradient(70% 50% at 50% 0,#4f46e52e 0%,#0000 70%)}.lp-hero-inner{z-index:1;max-width:720px;margin:0 auto;position:relative}.lp-eyebrow{background:var(--accent-soft);color:var(--accent);font-size:var(--text-xs);letter-spacing:.04em;text-transform:uppercase;margin-bottom:var(--space-5);border:1px solid #4f46e533;border-radius:9999px;padding:5px 14px;font-weight:700;display:inline-block}.lp-h1{font-family:var(--font-display);letter-spacing:-.04em;color:var(--text-primary);margin:0 0 var(--space-5);font-size:clamp(36px,6vw,58px);font-weight:800;line-height:1.08}.lp-accent{color:var(--accent)}.lp-hero-sub{color:var(--text-secondary);max-width:540px;margin:0 auto var(--space-8);font-size:clamp(16px,2vw,18px);line-height:1.65}.lp-hero-actions{margin-bottom:var(--space-6)}.lp-stats{justify-content:center;align-items:center;gap:var(--space-12);margin:var(--space-6) 0;flex-wrap:wrap;display:flex}.lp-stat-item{flex-direction:column;align-items:center;gap:3px;display:flex}.lp-stat-value{font-family:var(--font-display);color:var(--text-primary);letter-spacing:-.04em;font-size:clamp(24px,3.5vw,36px);font-weight:800;line-height:1}.lp-stat-label{font-size:var(--text-xs);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.07em;font-weight:500}.lp-chips{flex-wrap:wrap;justify-content:center;gap:8px;display:flex}.lp-chip{background:var(--bg-surface);border:1px solid var(--border);font-size:var(--text-xs);color:var(--text-secondary);border-radius:9999px;padding:5px 13px;font-weight:500}.lp-section{padding:80px var(--space-8);max-width:1040px;margin:0 auto}.lp-h2{font-family:var(--font-display);letter-spacing:-.03em;color:var(--text-primary);margin:0 0 var(--space-3);text-align:center;font-size:clamp(24px,3.5vw,36px);font-weight:800}.lp-section-sub{text-align:center;color:var(--text-secondary);font-size:var(--text-md);margin:0 auto var(--space-8);max-width:520px}.lp-grid{gap:var(--space-4);margin-top:var(--space-8);grid-template-columns:repeat(auto-fill,minmax(280px,1fr));display:grid}.lp-card{padding:var(--space-6);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);transition:border-color var(--transition), box-shadow var(--transition), transform var(--transition)}.lp-card:hover{border-color:#4f46e54d;transform:translateY(-2px);box-shadow:0 4px 20px #4f46e514}.lp-card-icon{border-radius:var(--radius-md);background:var(--accent-soft);width:40px;height:40px;color:var(--accent);margin-bottom:var(--space-4);justify-content:center;align-items:center;display:flex}[data-theme=dark] .lp-card-icon{background:#4f46e526}.lp-card-title{font-size:var(--text-md);color:var(--text-primary);margin:0 0 var(--space-2);letter-spacing:-.01em;font-weight:700}.lp-card-desc{font-size:var(--text-sm);color:var(--text-secondary);margin:0;line-height:1.6}.lp-steps-section{background:var(--bg-surface);border-radius:var(--radius-lg);max-width:1040px;padding:80px var(--space-8);margin:0 auto}.lp-steps{gap:var(--space-8);margin-top:var(--space-8);grid-template-columns:repeat(auto-fill,minmax(240px,1fr));display:grid}.lp-step{text-align:center}.lp-step-num{background:var(--accent);color:#fff;width:44px;height:44px;font-family:var(--font-display);font-size:var(--text-md);margin-bottom:var(--space-4);border-radius:50%;justify-content:center;align-items:center;font-weight:800;display:inline-flex;box-shadow:0 3px 12px #4f46e54d}.lp-step-title{font-size:var(--text-md);color:var(--text-primary);margin:0 0 var(--space-2);font-weight:700}.lp-step-desc{font-size:var(--text-sm);color:var(--text-secondary);margin:0;line-height:1.6}.lp-faq{max-width:680px;margin:var(--space-8) auto 0;flex-direction:column;gap:4px;display:flex}.faq-item{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-surface);overflow:hidden}.faq-q{font-size:var(--text-base);color:var(--text-primary);cursor:pointer;justify-content:space-between;align-items:center;gap:var(--space-4);padding:16px 20px;font-weight:600;list-style:none;display:flex}.faq-q::-webkit-details-marker{display:none}.faq-q:after{content:"+";color:var(--accent);flex-shrink:0;font-size:18px;font-weight:400}.faq-item[open] .faq-q:after{content:"-"}.faq-a{font-size:var(--text-sm);color:var(--text-secondary);margin:0;padding:0 20px 16px;line-height:1.65}.lp-cta{padding:96px var(--space-8);text-align:center;background:var(--accent)}.lp-cta-h2{font-family:var(--font-display);color:#fff;margin:0 0 var(--space-4);letter-spacing:-.03em;font-size:clamp(24px,4vw,38px);font-weight:800}.lp-cta-sub{font-size:var(--text-md);color:#ffffffd1;margin:0 0 var(--space-8)}.lp-cta .lp-btn-primary{color:var(--accent);background:#fff;box-shadow:0 2px 16px #00000029}.lp-cta .lp-btn-primary:hover{background:#ffffffeb;box-shadow:0 4px 24px #00000038}.lp-footer{padding:var(--space-6) var(--space-8);border-top:1px solid var(--border);justify-content:space-between;align-items:center;gap:var(--space-4);display:flex}.lp-footer-tag{font-size:var(--text-xs);color:var(--text-tertiary)}@media (width<=640px){.lp-nav{padding:0 var(--space-4)}.lp-links{display:none}.lp-hero{padding:64px var(--space-4) 48px}.lp-section,.lp-steps-section{padding:56px var(--space-4)}.lp-cta{padding:64px var(--space-4)}.lp-footer{text-align:center;gap:var(--space-2);flex-direction:column}.lp-stats{gap:var(--space-8)}}.home-page{align-items:stretch;gap:0;padding:0}.home-hero{justify-content:space-between;align-items:center;gap:var(--space-6);border-bottom:1px solid var(--border);flex-wrap:wrap;padding:28px 32px 20px;display:flex}.home-hero-left{flex-direction:column;gap:4px;min-width:0;display:flex}.home-greeting{font-family:var(--font-display);color:var(--text-primary);letter-spacing:-.03em;margin:0;font-size:1.5rem;font-weight:800}.home-sub{font-size:var(--text-sm);color:var(--text-tertiary);margin:0}.home-hero-stats{align-items:center;gap:var(--space-3);flex-wrap:wrap;display:flex}.home-kpi{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);text-align:center;min-width:60px;transition:border-color var(--transition);flex-direction:column;align-items:center;gap:2px;padding:10px 16px;display:flex}.home-kpi:hover{border-color:#4f46e54d}.home-kpi-icon{align-self:center;margin-bottom:2px}.home-kpi-fire{color:#fb923c}.home-kpi-xp{color:#fcd34d}.home-kpi-val{font-family:var(--font-display);color:var(--text-primary);letter-spacing:-.02em;font-size:1.15rem;font-weight:800;line-height:1}.home-kpi-label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;font-size:10px;font-weight:600}.home-kpi-cefr{color:var(--accent);letter-spacing:-.01em;font-size:1.05rem;font-weight:800;line-height:1}.home-progress-bar-wrap{align-items:center;gap:var(--space-3);border-bottom:1px solid var(--border);padding:12px 32px;display:flex}.home-progress-track{background:var(--surface-3);border-radius:9999px;flex:1;height:6px;overflow:hidden}.home-progress-fill{background:linear-gradient(90deg, var(--accent), #818cf8);border-radius:9999px;height:100%;transition:width .7s cubic-bezier(.22,1,.36,1)}.home-progress-label{color:var(--text-tertiary);white-space:nowrap;font-size:11px;font-weight:500}.home-due-banner{align-items:center;gap:var(--space-3);background:var(--accent-soft);border-radius:var(--radius-md);font:inherit;font-size:var(--text-sm);color:var(--accent);cursor:pointer;text-align:left;transition:background var(--transition), border-color var(--transition);border:1px solid #4f46e533;margin:16px 32px 0;padding:12px 16px;font-weight:500;display:flex}.home-due-banner:hover{background:#4f46e51f;border-color:#4f46e559}.home-due-banner strong{font-weight:800}.home-due-arrow{opacity:.6;margin-left:auto}@media (width<=640px){.home-hero{padding:20px 16px 16px}.home-progress-bar-wrap{padding:10px 16px}.home-due-banner{margin:12px 16px 0}.home-kpi{padding:8px 12px}}.profile-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);width:100%;max-width:480px;box-shadow:var(--shadow-sm);flex-direction:column;align-items:center;gap:24px;margin:40px auto;padding:40px 32px;display:flex}.profile-avatar-img{flex-shrink:0}.profile-info{text-align:center;flex-direction:column;gap:4px;display:flex}.profile-name{color:var(--text-primary);margin:0;font-size:1.4rem;font-weight:700}.profile-email{color:var(--text-secondary);margin:0;font-size:14px}.profile-section{width:100%}.profile-section-title{text-transform:uppercase;letter-spacing:.08em;color:var(--text-tertiary);margin:0 0 8px;font-size:11px;font-weight:700}.profile-rows{border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden}.profile-row{justify-content:space-between;align-items:center;gap:12px;padding:12px 16px;font-size:14px;display:flex}.profile-row+.profile-row{border-top:1px solid var(--border)}.profile-row-label{color:var(--text-secondary);flex-shrink:0;font-weight:500}.profile-row-value{color:var(--text-primary);text-align:right;text-overflow:ellipsis;white-space:nowrap;font-weight:500;overflow:hidden}.profile-actions{gap:10px;width:100%;display:flex}.profile-btn{border-radius:var(--r-md);font:inherit;cursor:pointer;transition:background var(--t), opacity var(--t), color var(--t);border:none;flex:1;padding:11px 16px;font-size:14px;font-weight:600}.profile-btn:hover{opacity:.85}.profile-btn-secondary{background:var(--surface-2);color:var(--text-primary);border:1px solid var(--border)}.profile-btn-secondary:hover{background:var(--surface-3);opacity:1}.profile-btn-outline-danger{color:var(--danger);border:1.5px solid var(--danger);background:0 0}.profile-btn-outline-danger:hover{background:var(--danger-light);opacity:1}.profile-danger-zone{border-top:1px solid var(--border);flex-direction:column;gap:12px;width:100%;padding-top:16px;display:flex}.profile-danger-title{text-transform:uppercase;letter-spacing:.08em;color:var(--danger);margin:0;font-size:11px;font-weight:700}.profile-btn-danger{background:var(--danger);color:#fff;width:100%}.profile-btn-danger:hover{opacity:1;background:#b91c1c}.profile-delete-confirm{flex-direction:column;gap:12px;display:flex}.profile-delete-msg{color:var(--danger);background:var(--danger-light);border:1px solid var(--danger-border);border-radius:var(--r-md);margin:0;padding:10px 14px;font-size:13px;line-height:1.55}.profile-delete-actions{gap:10px;display:flex}.profile-delete-actions .profile-btn{flex:1}.avatar{object-fit:cover;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.avatar-initials{background:var(--accent);color:#fff;letter-spacing:-.02em;-webkit-user-select:none;user-select:none;font-weight:700}.notfound{text-align:center;background:var(--bg);flex-direction:column;justify-content:center;align-items:center;gap:12px;min-height:100vh;padding:32px;display:flex}.notfound-code{color:var(--primary);font-size:6rem;font-weight:800;line-height:1}.notfound-title{color:var(--text-primary);margin:0;font-size:1.5rem;font-weight:700}.notfound-sub{color:var(--text-secondary);margin:0;font-size:15px}.notfound-btn{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:8px;margin-top:8px;padding:10px 28px;font-size:14px;font-weight:600;transition:opacity .15s}.notfound-btn:hover{opacity:.85}.theme-toggle{border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface-2);width:36px;height:36px;color:var(--text-2);cursor:pointer;transition:background var(--t), border-color var(--t), color var(--t);flex-shrink:0;justify-content:center;align-items:center;display:flex}.theme-toggle:hover{background:var(--surface-3);border-color:var(--border-2);color:var(--text-1)}.public-layout{background:var(--bg-primary);min-height:100vh;color:var(--text-primary);flex-direction:column;display:flex}.pub-nav{z-index:100;padding:0 var(--space-8);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);background:#ffffffe0;flex-shrink:0;justify-content:space-between;align-items:center;height:64px;display:flex;position:sticky;top:0}[data-theme=dark] .pub-nav{background:#0f0f11e0}.pub-wordmark{font-size:var(--text-base);color:var(--text-primary);letter-spacing:-.02em;cursor:pointer;font-weight:800;font:inherit;letter-spacing:-.02em;background:0 0;border:none;padding:0;font-weight:800}.pub-home-btn{border:1.5px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);font:inherit;font-size:var(--text-sm);cursor:pointer;transition:border-color var(--transition), color var(--transition);background:0 0;padding:7px 16px;font-weight:600}.pub-home-btn:hover{border-color:var(--accent);color:var(--accent)}.pub-content{width:100%;max-width:860px;padding:var(--space-12) var(--space-8);flex:1;margin:0 auto}.pub-footer{padding:var(--space-5) var(--space-8);border-top:1px solid var(--border);font-size:var(--text-xs);color:var(--text-tertiary);text-align:center}@media (width<=640px){.pub-nav{padding:0 var(--space-4)}.pub-content{padding:var(--space-8) var(--space-4)}}.app-footer{justify-content:space-between;align-items:center;gap:var(--space-4);border-top:1px solid var(--border);background:var(--surface);flex-wrap:wrap;flex-shrink:0;padding:10px 20px;display:flex}.footer-brand{align-items:center;gap:8px;min-width:0;display:flex}.footer-brand-name{color:var(--text-primary);letter-spacing:-.01em;white-space:nowrap;font-size:12px;font-weight:700}.footer-tagline{color:var(--text-tertiary);white-space:nowrap;font-size:11px}.footer-links{align-items:center;gap:12px;display:flex}.footer-link{color:var(--text-tertiary);cursor:pointer;transition:color var(--transition);background:0 0;border:none;padding:0;font-size:12px}.footer-link:hover{color:var(--accent)}.footer-copy{color:var(--text-tertiary);white-space:nowrap;font-size:11px}@media (width<=640px){.footer-tagline,.footer-copy{display:none}}.legal-page{max-width:720px;color:var(--text-primary);margin:0 auto;padding:32px 24px 64px;line-height:1.7}.legal-page h1{color:var(--text-primary);margin:0 0 8px;font-size:28px;font-weight:700}.legal-page h2{color:var(--text-primary);margin:32px 0 8px;font-size:17px;font-weight:700}.legal-page p,.legal-page ul{color:var(--text-secondary);margin:0 0 12px;font-size:14px}.legal-page ul{padding-left:20px}.legal-page li{margin-bottom:6px}.legal-page code{background:var(--surface-2);color:var(--primary);border-radius:4px;padding:1px 5px;font-family:monospace;font-size:12px}.legal-notice{color:var(--text-3)!important;margin-bottom:24px!important;font-size:12px!important}.legal-back{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;align-items:center;gap:6px;margin-bottom:24px;padding:0;font-size:13px;transition:color .15s;display:inline-flex}.legal-back:hover{color:var(--primary)}.dashboard{width:100%;max-width:760px;margin:0 auto;padding:16px}[data-theme=dark] .stat-value{background:linear-gradient(135deg,#a5b4fc,#818cf8);-webkit-background-clip:text;background-clip:text}.dashboard.loading,.dashboard.error{min-height:300px;color:var(--text-3);justify-content:center;align-items:center;font-size:.95rem;display:flex}.dashboard.error{color:var(--danger)}.dashboard-header{text-align:center;margin-bottom:18px}.dashboard-header h1{color:var(--text-1);letter-spacing:-.01em;margin:0;font-size:1.1rem;font-weight:800}.level-hero{background:var(--header);color:#fff;border-radius:var(--r-xl);align-items:center;gap:18px;margin-bottom:16px;padding:20px;display:flex}.level-hero-ring{background:conic-gradient(var(--emerald-400) var(--pct,0%), #ffffff29 0);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:76px;height:76px;padding:5px;display:flex}.level-hero-ring-inner{background:linear-gradient(135deg, var(--amber-400), var(--amber-500));border-radius:50%;flex-direction:column;justify-content:center;align-items:center;width:100%;height:100%;display:flex;box-shadow:0 4px 14px #f59e0b66}.level-hero-num{font-size:28px;font-weight:900;line-height:1}.level-hero-cap{text-transform:uppercase;letter-spacing:.08em;opacity:.8;margin-top:2px;font-size:10px}.level-hero-body{flex:1;min-width:0}.level-hero-top{justify-content:space-between;align-items:baseline;margin-bottom:8px;display:flex}.level-hero-top strong{letter-spacing:-.01em;font-size:1.25rem;font-weight:800}.level-hero-top span{opacity:.65;font-size:.78rem}.level-hero-track{border-radius:var(--r-full);background:#0000004d;height:8px;overflow:hidden}.level-hero-fill{border-radius:var(--r-full);background:linear-gradient(90deg, var(--emerald-400), var(--emerald-500));height:100%;transition:width .6s cubic-bezier(.22,1,.36,1)}.level-hero-meta{opacity:.8;flex-wrap:wrap;gap:12px;margin-top:10px;font-size:.78rem;display:flex}.badge-shelf{flex-wrap:wrap;gap:8px;margin-bottom:16px;display:flex}.badge{border-radius:var(--r-full);background:var(--surface);border:1.5px solid var(--border);box-shadow:var(--shadow-xs);color:var(--text-1);align-items:center;gap:6px;padding:6px 12px;font-size:.8rem;font-weight:600;display:inline-flex}.badge-emoji{font-size:1rem}.skills-panel{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-xl);box-shadow:var(--shadow-sm);margin-bottom:16px;padding:20px}.skills-panel h2{color:var(--text-1);margin:0 0 16px;font-size:.95rem;font-weight:700}.skill-row{margin-bottom:16px}.skill-row:last-child{margin-bottom:0}.skill-row-head{align-items:center;gap:8px;margin-bottom:6px;display:flex}.skill-name{color:var(--text-1);font-size:.88rem;font-weight:600}.skill-cefr{color:#fff;border-radius:var(--r-full);letter-spacing:.03em;padding:2px 9px;font-size:.66rem;font-weight:800}.skill-stat{color:var(--text-3);margin-left:auto;font-size:.78rem;font-weight:600}.skill-track{border-radius:var(--r-full);background:var(--surface-3);height:8px;overflow:hidden}.skill-fill{border-radius:var(--r-full);height:100%;transition:width .5s}.skill-rec{color:var(--primary);margin-top:4px;font-size:.73rem;font-weight:600;display:inline-block}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:10px;margin-bottom:16px;display:grid}.stat-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-xs);transition:transform var(--t), box-shadow var(--t);padding:14px 16px}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-card-header{color:var(--text-2);margin-bottom:4px;font-size:.75rem;font-weight:700}.stat-value{letter-spacing:-.03em;background:linear-gradient(135deg, var(--indigo-500), var(--indigo-700));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin:2px 0;font-size:2rem;font-weight:800}.stat-label{color:var(--text-3);margin-bottom:8px;font-size:.75rem}.stat-details{color:var(--text-3);border-top:1px solid var(--border);flex-direction:column;gap:2px;padding-top:8px;font-size:.72rem;display:flex}.stat-details span{display:block}.stat-details span.due{color:var(--danger);font-weight:600}.streak-card{border-left:3px solid #f97316}.vocab-card{border-left:3px solid #3b82f6}.mistakes-card{border-left:3px solid var(--danger)}.sessions-card{border-left:3px solid var(--success)}.daily-challenge{background:linear-gradient(135deg, var(--indigo-500), var(--indigo-700));border-radius:var(--r-xl);color:#fff;margin-bottom:16px;padding:18px 20px}.daily-challenge h2{margin:0 0 12px;font-size:.95rem;font-weight:700}.challenge-items{flex-direction:column;gap:8px;display:flex}.challenge-item{border-radius:var(--r-lg);transition:background var(--t);background:#ffffff1f;align-items:center;gap:10px;padding:10px 14px;font-size:.88rem;display:flex}.challenge-item:hover{background:#fff3}.challenge-item.empty{background:#ffffff26;justify-content:center;font-weight:600}.challenge-emoji{flex-shrink:0;font-size:1.2rem}.refresh-btn{font:inherit;background:var(--primary);color:#fff;border-radius:var(--r-full);cursor:pointer;transition:background var(--t), box-shadow var(--t), transform var(--t);border:none;margin:0 auto;padding:10px 24px;font-size:.88rem;font-weight:600;display:block}.refresh-btn:hover{background:var(--primary-dark);box-shadow:0 4px 14px #6366f159}.refresh-btn:active{transform:scale(.97)}@media (width<=480px){.stats-grid{grid-template-columns:repeat(2,1fr)}.level-hero{text-align:center;flex-direction:column}.level-hero-top{flex-direction:column;align-items:center;gap:2px}.level-hero-meta{justify-content:center}}.hangman{flex-direction:column;gap:20px;max-width:800px;margin:0 auto;padding:20px;display:flex}.hangman-header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.hangman-header h2{margin:0;font-size:28px}.hangman-score{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-radius:20px;padding:8px 16px;font-size:18px;font-weight:600}.hangman-header-right{align-items:center;gap:12px;display:flex}.hangman-level{border:2px solid #667eea;border-radius:8px;display:inline-flex;overflow:hidden}.hangman-level-btn{color:#667eea;cursor:pointer;background:#fff;border:none;padding:7px 14px;font-size:14px;font-weight:600;transition:all .15s}.hangman-level-btn+.hangman-level-btn{border-left:2px solid #667eea}.hangman-level-btn.active{color:#fff;background:#667eea}.hangman-loading,.hangman-error{text-align:center;padding:40px 20px;font-size:18px}.hangman-error{color:#d32f2f;margin-bottom:20px}.hangman-content{background:#fff;border-radius:12px;grid-template-columns:1fr 1.5fr;gap:30px;padding:20px;display:grid;box-shadow:0 2px 8px #0000001a}.hangman-visual{flex-direction:column;align-items:center;gap:20px;display:flex}.hangman-drawing{color:#333;background:#f5f5f5;border-radius:8px;justify-content:center;align-items:center;min-height:180px;padding:15px;font-family:Courier New,monospace;font-size:14px;line-height:1.3;display:flex}.hangman-lives{color:#d32f2f;background:#ffebee;border-radius:8px;padding:10px 20px;font-size:18px;font-weight:600}.hangman-game{flex-direction:column;gap:20px;display:flex}.hangman-word-display{text-align:center;letter-spacing:8px;color:#1565c0;background:#f5f5f5;border-radius:8px;padding:20px;font-family:Courier New,monospace;font-size:36px;font-weight:700}.hangman-wrong-letters{background:#fff3e0;border-left:4px solid #ff9800;border-radius:4px;padding:12px 16px}.hangman-wrong-letters p{color:#e65100;margin:0;font-size:14px}.hangman-status{text-align:center;border-radius:8px;padding:16px;font-size:16px;font-weight:600}.hangman-status.won{color:#2e7d32;background:#e8f5e9}.hangman-status.lost{color:#c62828;background:#ffebee}.hangman-status p{margin:8px 0 0;font-size:14px;font-weight:400}.hangman-alphabet{grid-template-columns:repeat(8,1fr);gap:6px;display:grid}.hangman-letter{color:#1565c0;cursor:pointer;background:#fff;border:2px solid #1565c0;border-radius:6px;padding:8px;font-size:14px;font-weight:600;transition:all .2s}.hangman-letter:hover:not(:disabled){color:#fff;background:#1565c0;transform:scale(1.05)}.hangman-letter:disabled{opacity:.5;cursor:not-allowed;color:#999;background:#f5f5f5}.hangman-letter.guessed{opacity:.6;color:#999;border-color:#999}.hangman-letter.guessed.wrong{color:#d32f2f;background:#ffebee;border-color:#d32f2f}.hangman-actions{gap:12px;margin-top:10px;display:flex}.hangman-btn{cursor:pointer;border:none;border-radius:8px;flex:1;padding:12px 16px;font-size:16px;font-weight:600;transition:all .2s}.hangman-next{color:#fff;background:#667eea}.hangman-next:hover{background:#5568d3}.hangman-show{color:#e65100;background:#fff3e0}.hangman-show:hover{background:#ffe0b2}.hangman-done{color:#333;background:#f5f5f5}.hangman-done:hover{background:#e0e0e0}.hangman-close-btn{color:#fff;cursor:pointer;background:#667eea;border:none;border-radius:8px;margin-top:20px;padding:12px 24px;font-size:16px}@media (prefers-color-scheme:dark){.hangman{color:#e0e0e0}.hangman-content{background:#1e1e1e;box-shadow:0 2px 8px #0000004d}.hangman-drawing{color:#e0e0e0;background:#2a2a2a}.hangman-word-display{color:#64b5f6;background:#2a2a2a}.hangman-wrong-letters{color:#ffb74d;background:#3e2723;border-left-color:#ff9800}.hangman-letter{color:#64b5f6;background:#2a2a2a;border-color:#64b5f6}.hangman-letter:hover:not(:disabled){color:#1e1e1e;background:#64b5f6}.hangman-letter:disabled{color:#666;background:#333}.hangman-done{color:#e0e0e0;background:#333}.hangman-done:hover{background:#444}}@media (width<=600px){.hangman-content{grid-template-columns:1fr}.hangman-alphabet{grid-template-columns:repeat(6,1fr)}.hangman-word-display{letter-spacing:4px;font-size:28px}.hangman-drawing{min-height:140px;font-size:12px}}:root{--bg-primary:#fff;--bg-surface:#f8f8fb;--text-primary:#0a0a0f;--text-secondary:#5a5a72;--text-tertiary:#9696a8;--border:#00000012;--accent:#4f46e5;--accent-hover:#4338ca;--accent-soft:#eef2ff;--success:#059669;--error:#dc2626;--warning:#d97706;--surface-3:#ededf4;--font-sans:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-display:"Plus Jakarta Sans", var(--font-sans);--text-xs:12px;--text-sm:13px;--text-base:14px;--text-md:16px;--text-lg:20px;--text-xl:24px;--text-2xl:32px;--text-3xl:42px;--text-4xl:56px;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--space-12:48px;--space-16:64px;--space-20:80px;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--shadow-card:0 2px 8px #0000000d;--shadow-modal:0 8px 32px #0000001f;--transition:.15s ease;--t-spring:.5s cubic-bezier(.22, 1, .36, 1);--bg:var(--bg-primary);--surface:var(--bg-surface);--surface-2:var(--bg-surface);--text-1:var(--text-primary);--text-2:var(--text-secondary);--text-3:var(--text-tertiary);--primary:var(--accent);--primary-dark:var(--accent-hover);--primary-light:var(--accent-soft);--primary-muted:#4f46e51a;--danger:var(--error);--danger-light:#fef2f2;--danger-border:#fecaca;--success-light:#f0fdf4;--success-border:#bbf7d0;--r-sm:var(--radius-sm);--r-md:var(--radius-md);--r-lg:var(--radius-lg);--r-xl:20px;--r-2xl:24px;--r-full:9999px;--shadow-xs:var(--shadow-card);--shadow-sm:0 2px 4px #0000000d;--shadow-md:var(--shadow-card);--shadow-lg:var(--shadow-modal);--shadow-xl:0 20px 40px #0000001f;--t:var(--transition);--border-2:#00000024;--header:var(--text-primary)}[data-theme=dark]{--bg-primary:#0f0f14;--bg-surface:#18181f;--text-primary:#f5f5fa;--text-secondary:#b0b0c8;--text-tertiary:#68687a;--border:#ffffff12;--accent-soft:#4f46e526;--bg:var(--bg-primary);--surface:var(--bg-surface);--surface-2:#1f1f28;--surface-3:#26262e;--text-1:var(--text-primary);--text-2:var(--text-secondary);--text-3:var(--text-tertiary);--primary-light:#4f46e52e;--primary-muted:#4f46e53d;--border-2:#ffffff24;--header:var(--text-primary);--danger-light:#dc262626;--danger-border:#dc262661;--success-light:#05966926;--success-border:#05966961;--shadow-xs:0 1px 2px #0006;--shadow-sm:0 2px 4px #0006;--shadow-md:0 4px 12px #00000073;--shadow-lg:0 10px 24px #00000080;--shadow-xl:0 20px 40px #0000008c;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}*,:before,:after{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:var(--font-sans);font-size:var(--text-base);background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.5;transition:background .2s,color .2s}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.001ms!important;animation-duration:.001ms!important;animation-iteration-count:1!important}}
