.lp-root{background:var(--paper);color:var(--ink);font-family:Plus Jakarta Sans,system-ui,sans-serif;overflow-x:hidden;position:relative;-webkit-font-smoothing:antialiased}.lp-root h1,.lp-root h2,.lp-root h3{font-family:"Baloo 2",system-ui,sans-serif;font-weight:800;letter-spacing:-.01em;line-height:1.05;margin:0}.lp-wrap{width:min(1180px,92vw);margin:0 auto}.lp-btn{font-family:"Baloo 2",system-ui,sans-serif;font-weight:700;font-size:1.05rem;border:none;cursor:pointer;border-radius:999px;padding:14px 30px;display:inline-flex;align-items:center;gap:10px;text-decoration:none;transition:transform .18s var(--bounce),box-shadow .18s var(--ease),background .2s var(--ease);will-change:transform}.lp-btn-primary{background:var(--coral);color:#fff;box-shadow:var(--pop-coral)}.lp-btn-primary:hover{transform:translateY(-3px);background:var(--coral-deep)}.lp-btn-primary:active{transform:translateY(1px);box-shadow:0 2px 0 var(--coral-deep)}.lp-btn-ghost{background:var(--surface);color:var(--ink);box-shadow:var(--pop);border:2px solid var(--line-strong)}.lp-btn-ghost:hover{transform:translateY(-3px)}.lp-btn-ghost:active{transform:translateY(1px);box-shadow:0 2px 0 var(--line-strong)}.lp-btn-grape{background:var(--grape);color:#fff;box-shadow:var(--pop-grape)}.lp-btn-grape:hover{transform:translateY(-3px);background:var(--grape-deep)}.lp-btn-grape:active{transform:translateY(1px);box-shadow:0 2px 0 var(--grape-deep)}.lp-btn-lg{padding:18px 40px;font-size:1.2rem}.lp-nav{position:sticky;top:0;z-index:50;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:color-mix(in srgb,var(--paper) 82%,transparent);border-bottom:1px solid var(--line)}.lp-nav-inner{display:flex;align-items:center;justify-content:space-between;height:68px}.lp-brand{display:flex;align-items:center;gap:8px;font-family:"Baloo 2",system-ui,sans-serif;font-weight:800;font-size:1.5rem;color:var(--ink);text-decoration:none}.lp-brand svg{transition:transform .3s var(--bounce)}.lp-brand:hover svg{transform:rotate(-8deg) scale(1.08)}.lp-nav-actions{display:flex;align-items:center;gap:16px}.lp-link{font-weight:700;color:var(--ink-soft);text-decoration:none;font-family:"Baloo 2",system-ui,sans-serif;padding:8px 14px;border-radius:999px;transition:color .2s,background .2s}.lp-link:hover{color:var(--ink);background:var(--surface-2)}.lp-hero{position:relative;padding:clamp(40px,8vw,90px) 0 clamp(50px,7vw,80px)}.lp-hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(24px,4vw,56px);align-items:center}.lp-eyebrow{display:inline-flex;align-items:center;gap:8px;background:var(--sun);color:var(--ink);font-family:"Baloo 2",system-ui,sans-serif;font-weight:700;font-size:.92rem;padding:7px 16px;border-radius:999px;box-shadow:var(--pop);transform:rotate(-2deg)}.lp-h1{font-size:clamp(2.6rem,6vw,4.6rem);margin:22px 0 0}.lp-h1 .lp-hi-coral{color:var(--coral)}.lp-h1 .lp-hi-grape{color:var(--grape)}.lp-h1 .lp-hi-mint{color:var(--mint-deep)}.lp-sub{font-size:clamp(1.05rem,2vw,1.3rem);color:var(--ink-soft);margin:22px 0 0;max-width:30ch;line-height:1.55}.lp-cta-row{display:flex;flex-wrap:wrap;gap:14px;margin-top:30px}.lp-trust{display:flex;flex-wrap:wrap;align-items:center;gap:10px 18px;margin-top:28px;color:var(--muted);font-weight:600;font-size:.95rem}.lp-trust span{display:inline-flex;align-items:center;gap:7px}.lp-trust .lp-dot{width:7px;height:7px;border-radius:50%;background:var(--mint)}.lp-stage{position:relative;display:flex;align-items:center;justify-content:center;min-height:380px}.lp-blob{position:absolute;top:6%;right:4%;bottom:6%;left:4%;background:var(--grad-warm);border-radius:46% 54% 60% 40%/52% 44% 56% 48%;filter:blur(2px);opacity:.9;z-index:0;animation:lp-morph 14s ease-in-out infinite}.lp-blob-2{top:16%;right:18%;bottom:16%;left:18%;background:var(--grad-cool);opacity:.55;animation-duration:18s;animation-direction:reverse}@keyframes lp-morph{0%,to{border-radius:46% 54% 60% 40%/52% 44% 56% 48%;transform:rotate(0)}50%{border-radius:60% 40% 44% 56%/44% 58% 42% 56%;transform:rotate(8deg)}}.lp-mascot{position:relative;z-index:2;filter:drop-shadow(0 24px 30px rgba(40,31,61,.18));animation:lp-bob 4.5s ease-in-out infinite}@keyframes lp-bob{0%,to{transform:translateY(0)}50%{transform:translateY(-14px)}}.lp-bubble{position:absolute;z-index:3;font-family:"Baloo 2",system-ui,sans-serif;font-weight:700;font-size:1.05rem;padding:10px 18px;border-radius:999px 999px 999px 6px;background:var(--surface);color:var(--ink);box-shadow:var(--pop);white-space:nowrap;animation:lp-float 7s ease-in-out infinite}.lp-bubble-1{top:4%;left:-2%;background:var(--surface);color:var(--coral);animation-delay:0s}.lp-bubble-2{top:12%;right:-4%;color:var(--grape);animation-delay:1.2s}.lp-bubble-3{bottom:24%;left:-6%;color:var(--mint-deep);animation-delay:2.4s}.lp-bubble-4{bottom:6%;right:2%;color:var(--sky);animation-delay:.6s}.lp-bubble-5{top:46%;right:-8%;color:var(--pink);animation-delay:1.8s}@keyframes lp-float{0%,to{transform:translateY(0) rotate(-2deg)}50%{transform:translateY(-16px) rotate(2deg)}}.lp-stats{padding:10px 0 clamp(40px,6vw,70px)}.lp-stat-grid{display:flex;flex-wrap:wrap;justify-content:center;gap:16px}.lp-stat{flex:1 1 200px;max-width:270px;background:var(--surface);border-radius:var(--r);padding:24px 22px;text-align:center;box-shadow:var(--pop);border:2px solid var(--line-strong);transition:transform .25s var(--bounce)}.lp-stat:hover{transform:translateY(-6px) rotate(-1deg)}.lp-stat-num{font-family:"Baloo 2",system-ui,sans-serif;font-weight:800;font-size:2.4rem;line-height:1}.lp-stat:nth-child(1) .lp-stat-num{color:var(--coral)}.lp-stat:nth-child(2) .lp-stat-num{color:var(--grape)}.lp-stat:nth-child(3) .lp-stat-num{color:var(--mint-deep)}.lp-stat:nth-child(4) .lp-stat-num{color:var(--sky)}.lp-stat-label{color:var(--ink-soft);font-weight:600;margin-top:8px;font-size:.98rem}.lp-section{padding:clamp(50px,8vw,100px) 0}.lp-section-alt{background:var(--paper-2)}.lp-head{text-align:center;max-width:40ch;margin:0 auto clamp(36px,5vw,56px)}.lp-kicker{font-family:"Baloo 2",system-ui,sans-serif;font-weight:700;text-transform:uppercase;letter-spacing:.12em;font-size:.82rem;color:var(--coral)}.lp-h2{font-size:clamp(2rem,4.5vw,3.2rem);margin-top:10px}.lp-head p{color:var(--ink-soft);font-size:1.12rem;margin:16px 0 0;line-height:1.55}.lp-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}.lp-step{position:relative;background:var(--surface);border-radius:var(--r-lg);padding:36px 28px 30px;box-shadow:var(--soft-lg);border:2px solid var(--line);transition:transform .3s var(--bounce),box-shadow .3s var(--ease)}.lp-step:hover{transform:translateY(-8px);box-shadow:var(--pop-lg)}.lp-step-badge{position:absolute;top:-18px;left:28px;width:40px;height:40px;border-radius:50%;display:grid;place-items:center;font-family:"Baloo 2",system-ui,sans-serif;font-weight:800;color:#fff;box-shadow:var(--pop)}.lp-step:nth-child(1) .lp-step-badge{background:var(--coral)}.lp-step:nth-child(2) .lp-step-badge{background:var(--grape)}.lp-step:nth-child(3) .lp-step-badge{background:var(--mint-deep)}.lp-step-emoji{font-size:2.8rem;line-height:1;display:block;margin:6px 0 16px}.lp-step h3{font-size:1.5rem}.lp-step p{color:var(--ink-soft);margin:10px 0 0;line-height:1.55}.lp-bento{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:1fr;gap:18px}.lp-bento-card{position:relative;overflow:hidden;isolation:isolate;border-radius:28px;padding:26px;min-height:200px;display:flex;flex-direction:column;justify-content:space-between;gap:18px;color:#fff;box-shadow:0 16px 38px #281f3d29;transition:transform .4s var(--bounce),box-shadow .4s var(--ease)}.lp-bento-card.is-hero{grid-column:span 2;grid-row:span 2;padding:38px}.lp-bento-card:hover{transform:translateY(-8px) rotate(-.5deg) scale(1.012);box-shadow:0 28px 60px #281f3d47}.lp-bento-blob{position:absolute;z-index:-1;width:220px;height:220px;right:-70px;top:-85px;background:#ffffff2e;border-radius:50%;transition:transform .5s var(--ease)}.lp-bento-card.is-hero .lp-bento-blob{width:360px;height:360px}.lp-bento-card:hover .lp-bento-blob{transform:scale(1.25) translate(-12px,14px)}.lp-bento-top{display:flex;align-items:center;justify-content:space-between;gap:12px}.lp-bento-icon{display:inline-grid;place-items:center;width:56px;height:56px;border-radius:18px;background:#ffffff38;box-shadow:inset 0 0 0 1px #fff6}.is-hero .lp-bento-icon{width:78px;height:78px;border-radius:24px}.lp-bento-tag{font-size:.72rem;font-weight:800;letter-spacing:.04em;text-transform:uppercase;padding:6px 13px;border-radius:999px;background:#ffffff3d;white-space:nowrap}.lp-bento-body h3{font-family:"Baloo 2",sans-serif;font-size:1.4rem;margin:0 0 6px;color:#fff}.is-hero .lp-bento-body h3{font-size:clamp(1.8rem,4vw,2.4rem)}.lp-bento-body p{margin:0;line-height:1.5;font-weight:500;color:#ffffffeb}.is-hero .lp-bento-body p{font-size:1.1rem;max-width:34ch}.lp-bento-card[data-accent=coral]{background:linear-gradient(140deg,#ff8f6f,#ff5a3c)}.lp-bento-card[data-accent=grape]{background:linear-gradient(140deg,#a08bff,#6f4ff0)}.lp-bento-card[data-accent=mint]{background:linear-gradient(140deg,#34dcab,#10b487)}.lp-bento-card[data-accent=sky]{background:linear-gradient(140deg,#62bcff,#2f93f0)}.lp-bento-card[data-accent=pink]{background:linear-gradient(140deg,#ffa3cd,#ff6fae)}.lp-bento-card[data-accent=sun]{background:linear-gradient(140deg,#ffdd71,#ffc01f);color:var(--ink)}.lp-bento-card[data-accent=sun] .lp-bento-body h3{color:var(--ink)}.lp-bento-card[data-accent=sun] .lp-bento-body p{color:#281f3dcc}.lp-bento-card[data-accent=sun] .lp-bento-icon,.lp-bento-card[data-accent=sun] .lp-bento-tag{background:#281f3d1f;box-shadow:none}.lp-langs{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.lp-lang{position:relative;background:var(--surface);border-radius:var(--r);padding:26px 24px;border:2px solid var(--line-strong);box-shadow:var(--pop);display:flex;align-items:center;gap:18px;cursor:pointer;transition:transform .25s var(--bounce),box-shadow .25s var(--ease);text-align:left;width:100%;font-family:inherit}.lp-lang:hover{transform:translateY(-6px) scale(1.015);box-shadow:var(--pop-lg)}.lp-lang-flag{font-size:2.6rem;line-height:1;flex-shrink:0;filter:drop-shadow(0 4px 6px rgba(40,31,61,.12))}.lp-lang-native{font-family:"Baloo 2",system-ui,sans-serif;font-weight:800;font-size:1.45rem;color:var(--ink)}.lp-lang-meta{color:var(--ink-soft);font-weight:600;font-size:.92rem;margin-top:2px}.lp-lang-level{display:inline-block;margin-top:8px;font-family:"Baloo 2",system-ui,sans-serif;font-weight:700;font-size:.8rem;padding:3px 12px;border-radius:999px;background:var(--surface-2);color:var(--grape);border:1px solid var(--line)}.lp-cta{position:relative;padding:clamp(56px,8vw,96px) 0;overflow:hidden}.lp-cta-card{position:relative;background:var(--grad-warm);border-radius:clamp(28px,4vw,48px);padding:clamp(40px,6vw,72px) clamp(28px,5vw,64px);text-align:center;box-shadow:var(--pop-lg);overflow:hidden}.lp-cta-card:before,.lp-cta-card:after{content:"";position:absolute;border-radius:50%;background:#ffffff38}.lp-cta-card:before{width:220px;height:220px;top:-80px;left:-60px}.lp-cta-card:after{width:280px;height:280px;bottom:-120px;right:-70px}.lp-cta-inner{position:relative;z-index:2}.lp-cta-mascot{animation:lp-bob 4s ease-in-out infinite}.lp-cta h2{color:#fff;font-size:clamp(2rem,5vw,3.4rem);margin:12px auto 0;max-width:18ch;text-shadow:0 4px 0 rgba(232,71,42,.25)}.lp-cta p{color:#ffffffeb;font-size:1.18rem;font-weight:600;margin:16px auto 0;max-width:36ch}.lp-cta .lp-btn{margin-top:30px;background:#fff;color:var(--coral-deep);box-shadow:0 6px #281f3d2e}.lp-cta .lp-btn:hover{transform:translateY(-3px)}.lp-cta .lp-btn:active{transform:translateY(1px);box-shadow:0 2px #281f3d2e}.lp-footer{background:var(--surface-2);border-top:1px solid var(--line);padding:clamp(40px,6vw,64px) 0 36px}.lp-footer-top{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:24px}.lp-footer .lp-brand{font-size:1.7rem}.lp-footer-tag{color:var(--ink-soft);font-weight:600;max-width:30ch;line-height:1.5}.lp-footer-links{margin-top:28px;display:flex;flex-wrap:wrap;gap:18px}.lp-footer-links a{color:var(--muted);text-decoration:none;font-weight:600;font-size:.92rem}.lp-footer-links a:hover{color:var(--coral)}.lp-footer-note{margin-top:18px;padding-top:22px;border-top:1px solid var(--line);color:var(--muted);font-weight:600;font-size:.92rem;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:12px}.lp-reveal{opacity:0;transform:translateY(28px);transition:opacity .6s var(--ease),transform .7s var(--bounce)}.lp-reveal.lp-in{opacity:1;transform:none}.lp-fadeup{animation:lp-fadeup .8s var(--bounce) both}.lp-fadeup-1{animation-delay:.05s}.lp-fadeup-2{animation-delay:.18s}.lp-fadeup-3{animation-delay:.31s}.lp-fadeup-4{animation-delay:.44s}@keyframes lp-fadeup{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}@media(max-width:920px){.lp-hero-grid{grid-template-columns:1fr;text-align:center}.lp-sub{max-width:none;margin-left:auto;margin-right:auto}.lp-cta-row,.lp-trust{justify-content:center}.lp-eyebrow{margin:0 auto}.lp-stage{order:-1;min-height:320px}.lp-steps,.lp-langs,.lp-bento{grid-template-columns:repeat(2,1fr)}.lp-bento-card.is-hero{grid-column:span 2;grid-row:span 1}}@media(max-width:620px){.lp-steps,.lp-langs,.lp-bento{grid-template-columns:1fr}.lp-bento-card.is-hero{grid-column:span 1}.lp-nav-actions .lp-link{display:none}.lp-btn{font-size:1rem;padding:12px 24px}.lp-bubble{font-size:.9rem;padding:8px 14px}.lp-bubble-5{display:none}.lp-nav-inner{height:58px}.lp-brand{font-size:1.3rem}.lp-nav-actions{gap:8px}.lp-nav-actions .lp-btn{padding:10px 18px;font-size:.95rem}.lp-cta-row{flex-direction:column;align-items:stretch;gap:12px}.lp-cta-row .lp-btn{width:100%;justify-content:center}.lp-btn-lg{padding:16px 28px;font-size:1.1rem}.lp-section{padding:clamp(40px,11vw,64px) 0}.lp-hero{padding:clamp(28px,9vw,52px) 0 clamp(34px,8vw,48px)}.lp-stage{min-height:260px}.lp-bubble-1{left:2%}.lp-bubble-2{right:0%}.lp-bubble-3{left:0%}.lp-stat{flex:1 1 140px}}@media(max-width:420px){.lp-stat-grid{gap:12px}.lp-stat{flex:1 1 100%;max-width:100%;padding:18px}.lp-stat-num{font-size:2rem}.lp-bubble-2,.lp-bubble-3{display:none}.lp-cta-card{padding:36px 20px}.lp-h1{font-size:clamp(2.1rem,11vw,2.8rem)}}@media(prefers-reduced-motion:reduce){.lp-mascot,.lp-blob,.lp-bubble,.lp-cta-mascot{animation:none}.lp-reveal{opacity:1;transform:none;transition:none}.lp-fadeup{animation:none}}.ob-root{position:relative;min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:1.5rem;background:radial-gradient(1200px 700px at 15% -10%,rgba(255,122,182,.18),transparent 60%),radial-gradient(1000px 600px at 110% 10%,rgba(124,92,252,.16),transparent 55%),radial-gradient(900px 600px at 50% 120%,rgba(22,199,154,.14),transparent 55%),var(--paper);overflow:hidden;font-family:Plus Jakarta Sans,sans-serif;color:var(--ink)}.ob-bg{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0}.ob-blob{position:absolute;border-radius:50%;filter:blur(2px);opacity:.55;animation:ob-float 9s var(--ease) infinite alternate}.ob-blob-1{width:140px;height:140px;background:var(--grad-warm);top:8%;left:6%}.ob-blob-2{width:90px;height:90px;background:var(--grad-cool, linear-gradient(135deg, #3da5ff, #7c5cfc));bottom:12%;left:12%;animation-delay:1.2s}.ob-blob-3{width:120px;height:120px;background:var(--grad-mint, linear-gradient(135deg, #16c79a, #3da5ff));top:16%;right:8%;animation-delay:.6s}@keyframes ob-float{0%{transform:translateY(0) rotate(0)}to{transform:translateY(-26px) rotate(8deg)}}.ob-card{position:relative;z-index:1;width:100%;max-width:560px;background:var(--surface);border:2px solid var(--line-strong);border-radius:var(--r-lg);box-shadow:var(--pop-lg),var(--soft-lg, 0 30px 60px -20px rgba(40, 31, 61, .25));padding:1.6rem 1.6rem 2rem;animation:ob-card-in .5s var(--bounce) both}@keyframes ob-card-in{0%{opacity:0;transform:translateY(22px) scale(.96)}to{opacity:1;transform:none}}.ob-progress{display:flex;align-items:center;gap:.9rem;margin-bottom:1.4rem}.ob-bar{position:relative;flex:1;height:10px;background:var(--surface-2);border:2px solid var(--line);border-radius:999px;overflow:hidden}.ob-bar-fill{position:absolute;top:0;right:0;bottom:0;left:0;width:0;border-radius:999px;background:var(--grad-warm);transition:width .55s var(--bounce)}.ob-dots{display:flex;gap:.4rem}.ob-dot{width:11px;height:11px;border-radius:50%;border:2px solid var(--line-strong);background:var(--surface);padding:0;cursor:pointer;transition:transform .22s var(--bounce),background .22s var(--ease),border-color .22s var(--ease)}.ob-dot:disabled{cursor:default}.ob-dot.is-done{background:var(--mint);border-color:var(--mint-deep)}.ob-dot.is-active{background:var(--coral);border-color:var(--coral-deep);transform:scale(1.35)}.ob-stage{position:relative}.ob-dir-fwd .ob-step{animation:ob-slide-fwd .45s var(--ease) both}.ob-dir-back .ob-step{animation:ob-slide-back .45s var(--ease) both}@keyframes ob-slide-fwd{0%{opacity:0;transform:translate(34px)}to{opacity:1;transform:none}}@keyframes ob-slide-back{0%{opacity:0;transform:translate(-34px)}to{opacity:1;transform:none}}.ob-step{display:flex;flex-direction:column;gap:1.1rem}.ob-step-center{align-items:center;text-align:center}.ob-mascot{display:inline-flex}.ob-mascot-lg{filter:drop-shadow(0 12px 18px rgba(40,31,61,.18));animation:ob-bob 3.4s var(--ease) infinite alternate}@keyframes ob-bob{0%{transform:translateY(0)}to{transform:translateY(-10px)}}.ob-mascot-pop{animation:ob-mascot-pop .6s var(--bounce) both,ob-bob 3.4s var(--ease) infinite alternate .6s}@keyframes ob-mascot-pop{0%{transform:scale(.4) rotate(-12deg);opacity:0}60%{transform:scale(1.12) rotate(6deg)}to{transform:scale(1) rotate(0);opacity:1}}.ob-mascot-sm{flex-shrink:0;filter:drop-shadow(0 8px 12px rgba(40,31,61,.14))}.ob-h1{font-family:"Baloo 2",sans-serif;font-weight:800;font-size:clamp(1.6rem,5vw,2.1rem);line-height:1.12;letter-spacing:-.02em;margin:0;color:var(--ink);outline:none}.ob-h2{font-family:"Baloo 2",sans-serif;font-weight:800;font-size:clamp(1.25rem,3.6vw,1.55rem);line-height:1.15;letter-spacing:-.02em;margin:0;color:var(--ink);outline:none}.ob-emoji{display:inline-block;animation:ob-wiggle 2.4s var(--ease) infinite}@keyframes ob-wiggle{0%,88%,to{transform:rotate(0)}92%{transform:rotate(16deg)}96%{transform:rotate(-12deg)}}.ob-sub{margin:.25rem 0 0;color:var(--ink-soft);font-size:.95rem;font-weight:500}.ob-bubble{position:relative;max-width:420px;margin:0 auto;background:var(--surface-2);border:2px solid var(--line);border-radius:var(--r);padding:.95rem 1.15rem;color:var(--ink-soft);font-size:1rem;line-height:1.5;font-weight:500;box-shadow:var(--pop)}.ob-bubble:before{content:"";position:absolute;top:-11px;left:50%;transform:translate(-50%);width:18px;height:18px;background:var(--surface-2);border-top:2px solid var(--line);border-left:2px solid var(--line);border-radius:4px 0 0;rotate:45deg}.ob-head{display:flex;align-items:center;gap:.9rem}.ob-btn{font-family:"Baloo 2",sans-serif;font-weight:800;font-size:1.05rem;border:2px solid transparent;border-radius:var(--r);padding:.85rem 1.5rem;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:.4rem;letter-spacing:-.01em;transition:transform .14s var(--bounce),box-shadow .14s var(--ease),filter .18s var(--ease),background .18s var(--ease);-webkit-user-select:none;user-select:none}.ob-btn:focus-visible{outline:3px solid var(--grape);outline-offset:3px}.ob-btn-primary{background:var(--coral);color:#fff;border-color:var(--coral-deep);box-shadow:var(--pop-coral)}.ob-btn-primary:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 8px 0 var(--coral-deep);filter:saturate(1.08)}.ob-btn-primary:active:not(:disabled){transform:translateY(2px);box-shadow:0 1px 0 var(--coral-deep)}.ob-btn-primary:disabled{background:var(--line-strong);border-color:var(--line-strong);color:var(--muted);box-shadow:var(--pop);cursor:not-allowed;filter:none}.ob-btn-xl{font-size:1.18rem;padding:1rem 2rem;border-radius:var(--r-lg);margin-top:.3rem}.ob-btn-ghost{background:var(--surface);color:var(--ink-soft);border-color:var(--line-strong);box-shadow:var(--pop)}.ob-btn-ghost:hover{transform:translateY(-2px);box-shadow:var(--pop-lg);color:var(--ink)}.ob-btn-ghost:active{transform:translateY(2px);box-shadow:0 1px 0 var(--line-strong)}.ob-btn-sm{font-size:.95rem;padding:.6rem 1.1rem}.ob-arrow{display:inline-block;transition:transform .2s var(--bounce)}.ob-btn-primary:hover:not(:disabled) .ob-arrow{transform:translate(4px)}.ob-btn-wiggle{animation:ob-cta-pulse 2.2s var(--ease) infinite}@keyframes ob-cta-pulse{0%,to{box-shadow:var(--pop-coral)}50%{box-shadow:0 5px 0 var(--coral-deep),0 0 0 8px #ff6b4a24}}.ob-actions{display:flex;justify-content:space-between;align-items:center;gap:.8rem;margin-top:.4rem}.ob-actions-center{justify-content:center;margin-top:.2rem}.ob-skip{align-self:center;background:none;border:none;color:var(--muted);font-family:Plus Jakarta Sans,sans-serif;font-weight:600;font-size:.88rem;cursor:pointer;padding:.4rem .6rem;border-radius:999px;transition:color .18s var(--ease),background .18s var(--ease)}.ob-skip:hover{color:var(--ink-soft);background:var(--surface-2)}.ob-lang-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.7rem}.ob-lang-card{position:relative;display:flex;flex-direction:column;align-items:center;gap:.2rem;padding:1rem .6rem .85rem;background:var(--surface);border:2px solid var(--line-strong);border-radius:var(--r);box-shadow:var(--pop);cursor:pointer;font-family:Plus Jakarta Sans,sans-serif;transition:transform .16s var(--bounce),box-shadow .16s var(--ease),border-color .18s var(--ease),background .2s var(--ease)}.ob-lang-card:hover{transform:translateY(-4px) rotate(-1.2deg);box-shadow:var(--pop-lg);border-color:var(--tint)}.ob-lang-card:active{transform:translateY(1px);box-shadow:0 1px 0 var(--line-strong)}.ob-lang-card:focus-visible{outline:3px solid var(--grape);outline-offset:3px}.ob-flag{font-size:2.1rem;line-height:1;transition:transform .25s var(--bounce)}.ob-lang-card:hover .ob-flag{transform:scale(1.18) rotate(6deg)}.ob-lang-native{font-family:"Baloo 2",sans-serif;font-weight:800;font-size:1.02rem;color:var(--ink);margin-top:.2rem;text-align:center}.ob-lang-name{font-size:.72rem;font-weight:600;color:var(--muted);letter-spacing:.02em}.ob-lang-card.is-selected{background:var(--tint);border-color:var(--tint-deep);box-shadow:0 5px 0 var(--tint-deep);transform:translateY(-2px)}.ob-lang-card.is-selected .ob-lang-native,.ob-lang-card.is-selected .ob-lang-name{color:#fff}.ob-lang-card.is-selected:hover{transform:translateY(-4px) rotate(-1.2deg)}.ob-check{position:absolute;top:-8px;right:-8px;width:24px;height:24px;border-radius:50%;background:var(--mint);color:#fff;border:2px solid #fff;display:grid;place-items:center;font-size:.8rem;font-weight:800;box-shadow:0 2px 6px #281f3d38;transform:scale(0);transition:transform .28s var(--bounce)}.ob-lang-card.is-selected .ob-check,.ob-goal-card.is-selected .ob-check{transform:scale(1)}.ob-chips{display:flex;flex-wrap:wrap;gap:.65rem;justify-content:center}.ob-chip{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.2rem;background:var(--surface);border:2px solid var(--line-strong);border-radius:999px;box-shadow:var(--pop);font-family:"Baloo 2",sans-serif;font-weight:800;font-size:1rem;color:var(--ink);cursor:pointer;transition:transform .16s var(--bounce),box-shadow .16s var(--ease),background .2s var(--ease),border-color .18s var(--ease),color .18s var(--ease)}.ob-chip:hover{transform:translateY(-3px) rotate(-1.5deg);box-shadow:var(--pop-lg);border-color:var(--grape)}.ob-chip:active{transform:translateY(1px);box-shadow:0 1px 0 var(--line-strong)}.ob-chip:focus-visible{outline:3px solid var(--grape);outline-offset:3px}.ob-chip.is-selected{background:var(--grape);border-color:var(--grape-deep);color:#fff;box-shadow:var(--pop-grape)}.ob-chip-emoji{font-size:1.2rem}.ob-goal-list{display:flex;flex-direction:column;gap:.6rem}.ob-goal-card{position:relative;display:flex;align-items:center;gap:.85rem;padding:.85rem 1.1rem;background:var(--surface);border:2px solid var(--line-strong);border-radius:var(--r);box-shadow:var(--pop);cursor:pointer;text-align:left;font-family:Plus Jakarta Sans,sans-serif;transition:transform .16s var(--bounce),box-shadow .16s var(--ease),background .2s var(--ease),border-color .18s var(--ease)}.ob-goal-card:hover{transform:translateY(-3px);box-shadow:var(--pop-lg);border-color:var(--sun)}.ob-goal-card:active{transform:translateY(1px);box-shadow:0 1px 0 var(--line-strong)}.ob-goal-card:focus-visible{outline:3px solid var(--grape);outline-offset:3px}.ob-goal-emoji{font-size:1.6rem;line-height:1}.ob-goal-text{display:flex;flex-direction:column;flex:1}.ob-goal-label{font-family:"Baloo 2",sans-serif;font-weight:800;font-size:1.08rem;color:var(--ink)}.ob-goal-mins{font-size:.82rem;font-weight:600;color:var(--muted)}.ob-goal-xp{font-family:"Baloo 2",sans-serif;font-weight:800;font-size:.95rem;color:var(--coral);background:var(--surface-2);border:2px solid var(--line);padding:.3rem .7rem;border-radius:999px;white-space:nowrap;transition:color .18s var(--ease),background .2s var(--ease),border-color .18s var(--ease)}.ob-goal-card.is-selected{background:var(--grad-sun, linear-gradient(135deg, #ffd76b, #ffc93c));border-color:#e0a91f;box-shadow:0 5px #e0a91f;transform:translateY(-2px)}.ob-goal-card.is-selected .ob-goal-xp{background:#fff;border-color:#fff;color:var(--coral-deep)}.ob-recap{display:flex;flex-direction:column;gap:.6rem;width:100%;max-width:380px;margin:.2rem auto 0}.ob-recap-item{display:flex;align-items:center;gap:.85rem;padding:.75rem 1rem;background:var(--surface-2);border:2px solid var(--line);border-radius:var(--r);text-align:left}.ob-recap-icon{font-size:1.7rem;line-height:1}.ob-recap-body{display:flex;flex-direction:column}.ob-recap-label{font-size:.76rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}.ob-recap-value{font-family:"Baloo 2",sans-serif;font-weight:800;font-size:1.05rem;color:var(--ink)}.ob-referral{width:100%;max-width:340px;margin-top:.5rem}.ob-referral-label{display:flex;flex-direction:column;gap:.35rem;font-size:.82rem;font-weight:500;color:var(--muted);text-align:center}.ob-referral-input{width:100%;padding:.55rem .8rem;border:1.5px solid var(--border);border-radius:12px;background:var(--paper);font-family:inherit;font-size:.9rem;font-weight:600;text-align:center;text-transform:uppercase;letter-spacing:1px;color:var(--ink);transition:border-color .2s}.ob-referral-input:focus{outline:none;border-color:var(--grape);box-shadow:0 0 0 3px #7c5cfc1f}.ob-referral-input::placeholder{text-transform:none;letter-spacing:0;font-weight:400;color:var(--muted);opacity:.6}.ob-confetti{position:fixed;top:0;right:0;bottom:0;left:0;z-index:5;pointer-events:none;overflow:hidden}.ob-confetti-piece{position:absolute;top:-20px;display:block;opacity:.95;animation-name:ob-fall;animation-timing-function:linear;animation-iteration-count:infinite}@keyframes ob-fall{0%{transform:translateY(-20px) rotate(0);opacity:0}10%{opacity:1}to{transform:translateY(105vh) rotate(680deg);opacity:.9}}@media(max-width:600px){.ob-root{padding:1rem .85rem}}@media(max-width:480px){.ob-card{padding:1.2rem 1.1rem 1.6rem;border-radius:var(--r)}.ob-lang-grid{grid-template-columns:repeat(2,1fr)}.ob-head{flex-direction:column;text-align:center;gap:.6rem}.ob-actions{flex-direction:row}.ob-btn{font-size:.98rem;padding:.8rem 1.2rem;min-height:44px}.ob-btn-xl{width:100%}.ob-mascot-lg svg,.ob-mascot-pop svg{max-height:130px}.ob-bubble{font-size:.95rem;padding:.85rem 1rem}.ob-dot{width:13px;height:13px}.ob-chip{font-size:.95rem;padding:.7rem 1rem}}@media(max-width:360px){.ob-card{padding:1.05rem .9rem 1.4rem}.ob-lang-grid{grid-template-columns:1fr 1fr;gap:.55rem}.ob-lang-card{padding:.85rem .5rem .7rem}.ob-flag{font-size:1.85rem}.ob-h1{font-size:clamp(1.4rem,7vw,1.8rem)}}@media(prefers-reduced-motion:reduce){.ob-card,.ob-step,.ob-mascot-lg,.ob-mascot-pop,.ob-blob,.ob-emoji,.ob-btn-wiggle,.ob-confetti-piece{animation:none!important}.ob-bar-fill{transition:width .2s linear}.ob-btn,.ob-lang-card,.ob-chip,.ob-goal-card,.ob-arrow,.ob-flag{transition:background .15s,color .15s,border-color .15s,box-shadow .15s}.ob-btn:hover,.ob-lang-card:hover,.ob-chip:hover,.ob-goal-card:hover{transform:none}.ob-confetti{display:none}}.legal-page{min-height:100vh;background:var(--paper);color:var(--ink);padding:0 1.25rem 5rem}.legal-head{max-width:760px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:1.25rem 0}.legal-brand{display:inline-flex;align-items:center;gap:.5rem;font-family:"Baloo 2",sans-serif;font-weight:800;font-size:1.4rem;color:var(--ink);text-decoration:none}.legal-back{color:var(--ink-soft);text-decoration:none;font-weight:600;font-size:.95rem}.legal-back:hover{color:var(--coral)}.legal-tabs{max-width:760px;margin:0 auto 1.5rem;display:flex;gap:.5rem;flex-wrap:wrap}.legal-tab{padding:.5rem 1rem;border-radius:999px;background:#fff;border:2px solid #f0e6d8;color:var(--ink-soft);text-decoration:none;font-weight:700;font-size:.95rem}.legal-tab.on{background:var(--coral);border-color:var(--coral);color:#fff}.legal-doc{max-width:760px;margin:0 auto;background:#fff;border:2px solid #f0e6d8;border-radius:22px;padding:clamp(1.5rem,4vw,2.75rem);line-height:1.7}.legal-doc h1{font-family:"Baloo 2",sans-serif;font-size:clamp(1.6rem,5vw,2.2rem);margin:0 0 .25rem}.legal-date{color:var(--ink-soft);font-size:.9rem;margin:0 0 1.5rem}.legal-doc h3{font-family:"Baloo 2",sans-serif;font-size:1.15rem;margin:1.75rem 0 .5rem}.legal-doc p{margin:0 0 .85rem}.legal-doc ul{margin:0 0 .85rem;padding-left:1.25rem}.legal-doc li{margin-bottom:.4rem}.legal-doc a{color:var(--coral-deep);font-weight:600}.legal-note{margin-top:2rem!important;padding-top:1.25rem;border-top:1px dashed #e7dcc9;color:var(--ink-soft);font-size:.88rem}.auth-root{position:relative;min-height:100vh;min-height:100dvh;display:grid;place-items:center;padding:1.5rem;background:var(--paper);overflow:hidden}.auth-bg{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none}.auth-blob{position:absolute;border-radius:50%;filter:blur(8px);opacity:.4}.auth-blob-1{width:320px;height:320px;background:radial-gradient(circle at 30% 30%,#ffb3a0,transparent 70%);top:-80px;right:-60px}.auth-blob-2{width:280px;height:280px;background:radial-gradient(circle at 30% 30%,#b9a8ff,transparent 70%);bottom:-70px;left:-50px}.auth-card{position:relative;z-index:1;width:100%;max-width:420px;background:#fff;border:2px solid #f0e6d8;border-radius:26px;box-shadow:0 18px 50px #281f3d1f;padding:clamp(1.5rem,5vw,2.5rem);text-align:center}.auth-brand{display:inline-flex;align-items:center;gap:.5rem;font-family:"Baloo 2",sans-serif;font-weight:800;font-size:1.8rem;color:var(--ink);text-decoration:none;margin-bottom:.75rem}.auth-brand .brand-mark{color:var(--coral)}.auth-title{font-family:"Baloo 2",sans-serif;font-size:clamp(1.5rem,5vw,2rem);margin:0 0 .35rem;color:var(--ink)}.auth-sub{color:var(--ink-soft);margin:0 0 1.5rem;line-height:1.5}.auth-devhint{color:var(--mint-deep);font-style:italic;font-size:.85em}.auth-form{display:flex;flex-direction:column;gap:1rem;text-align:left}.auth-field span{display:block;font-weight:700;font-size:.9rem;margin-bottom:.4rem;color:var(--ink)}.auth-field input{width:100%;padding:.85rem 1rem;border:2px solid #ece2d2;border-radius:14px;font:inherit;font-size:1rem;background:#fffdf9;color:var(--ink);transition:border-color .15s,box-shadow .15s}.auth-field input:focus{outline:none;border-color:var(--coral);box-shadow:0 0 0 4px #ff6b4a26}.auth-pw{position:relative}.auth-pw input{padding-right:3rem}.auth-eye{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);background:none;border:none;padding:.4rem;color:var(--ink-soft);cursor:pointer;display:inline-flex}.auth-eye:hover{color:var(--coral)}.auth-error{background:#fff0ec;border:1.5px solid #ffc4b5;color:var(--coral-deep);padding:.6rem .85rem;border-radius:12px;font-size:.9rem;font-weight:600}.auth-btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.95rem 1.25rem;border:none;border-radius:16px;background:var(--coral);color:#fff;font-family:"Baloo 2",sans-serif;font-weight:700;font-size:1.05rem;cursor:pointer;box-shadow:0 5px 0 var(--coral-deep);transition:transform .1s,box-shadow .1s,opacity .15s}.auth-btn:hover:not(:disabled){transform:translateY(-1px)}.auth-btn:active:not(:disabled){transform:translateY(3px);box-shadow:0 2px 0 var(--coral-deep)}.auth-btn:disabled{opacity:.6;cursor:default}.auth-link{background:none;border:none;color:var(--ink-soft);font-weight:600;cursor:pointer;margin-top:1rem;font-size:.9rem}.auth-link:hover{color:var(--coral)}.auth-switch-row{margin-top:1.25rem;color:var(--ink-soft);font-size:.95rem}.auth-switch{background:none;border:none;color:var(--coral-deep);font-weight:800;cursor:pointer;font-size:inherit;padding:0}.auth-switch:hover{text-decoration:underline}.auth-legal{margin-top:1.5rem;font-size:.8rem;color:var(--ink-soft);line-height:1.5}.auth-legal a{color:var(--coral-deep);font-weight:600}.auth-redeem-note{margin-top:1.5rem;display:flex;flex-direction:column;gap:.5rem;align-items:center;color:var(--ink-soft);font-size:.9rem}.auth-consent{display:flex;gap:.6rem;align-items:flex-start;font-size:.85rem;color:var(--ink-soft);line-height:1.45;text-align:left}.auth-consent input{margin-top:.2rem;width:18px;height:18px;flex-shrink:0;accent-color:var(--coral)}.auth-consent a{color:var(--coral-deep);font-weight:600}.verify-icon-wrapper{display:flex;align-items:center;justify-content:center;width:80px;height:80px;margin:.5rem auto 1rem;border-radius:50%;background:linear-gradient(135deg,#f5f0ff,#ede4ff);color:var(--grape, #6d28d9);animation:verify-pulse 2s ease-in-out infinite}@keyframes verify-pulse{0%,to{transform:scale(1);box-shadow:0 0 #6d28d926}50%{transform:scale(1.05);box-shadow:0 0 0 12px #6d28d900}}.auth-success{background:#ecfdf5;border:1.5px solid #a7f3d0;color:#065f46;padding:.6rem .85rem;border-radius:12px;font-size:.9rem;font-weight:600}.verify-actions{display:flex;flex-direction:column;align-items:center;gap:.5rem;margin-top:1.25rem}.verify-logout{color:var(--ink-soft);opacity:.7;font-size:.85rem}.verify-logout:hover{opacity:1;color:var(--coral)}.ad-screen{min-height:100vh;background:radial-gradient(1200px 600px at 80% -10%,#1a1f38,#0c0e1a 55%);color:#e9ebf6;padding:clamp(1rem,4vw,2.5rem);font-family:Plus Jakarta Sans,sans-serif}.ad-center{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;text-align:center;min-height:70vh}.ad-404{font-size:4rem;margin:0;font-family:"Baloo 2",sans-serif}.ad-home{color:#9db0ff;text-decoration:none;font-weight:700}.ad-head{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;margin-bottom:1.75rem}.ad-eyebrow{font-size:.72rem;letter-spacing:.14em;font-weight:800;color:#7c8bd0}.ad-head h1{font-family:"Baloo 2",sans-serif;font-size:clamp(1.6rem,4vw,2.3rem);margin:.2rem 0 0}.ad-kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:14px;margin-bottom:18px}.ad-kpi{--accent: #7c5cfc;position:relative;overflow:hidden;background:linear-gradient(160deg,#171c30,#12162600 60%),#141829;border:1px solid #232a45;border-radius:18px;padding:1.1rem 1.2rem}.ad-kpi:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--accent)}.ad-kpi-val{font-family:"Baloo 2",sans-serif;font-size:2rem;font-weight:800;color:#fff;line-height:1}.ad-kpi-label{color:#9aa3c8;font-size:.82rem;margin-top:.4rem}.ad-kpi-sub{color:var(--accent);font-size:.78rem;font-weight:700;margin-top:.25rem}.ad-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}@media(max-width:760px){.ad-row{grid-template-columns:1fr}}.ad-card{background:#141829;border:1px solid #232a45;border-radius:18px;padding:1.25rem 1.35rem;margin-bottom:14px}.ad-card-h{display:flex;align-items:baseline;justify-content:space-between;gap:1rem;margin-bottom:1rem}.ad-card-h h2{font-family:"Baloo 2",sans-serif;font-size:1.05rem;margin:0;color:#d7dcf3}.ad-card-h span{color:#7c8bd0;font-size:.82rem;font-weight:700}.ad-msg{color:#16c79a!important}.ad-spark{width:100%;height:130px;display:block}.ad-donut-wrap{display:flex;align-items:center;gap:1.4rem;flex-wrap:wrap}.ad-donut{width:120px;height:120px;flex-shrink:0}.ad-legend{list-style:none;margin:0;padding:0;display:grid;gap:.4rem;font-size:.85rem;color:#c2c8e6}.ad-legend li{display:flex;align-items:center;gap:.5rem}.ad-legend b{color:#fff;margin-left:auto}.ad-dot{width:10px;height:10px;border-radius:50%}.ad-list{list-style:none;margin:0;padding:0}.ad-list li{display:flex;justify-content:space-between;padding:.55rem 0;border-bottom:1px solid #222742}.ad-list li:last-child{border-bottom:none}.ad-list b{color:#fff}.ad-empty{color:#6b7299;font-size:.9rem;padding:.6rem 0}.ad-promo-form{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:1.2rem}.ad-promo-form input{flex:1 1 130px;min-width:0;padding:.6rem .8rem;border-radius:11px;border:1px solid #2b3354;background:#0f1322;color:#e9ebf6;font:inherit;font-size:.9rem}.ad-promo-form input:focus{outline:none;border-color:#7c5cfc}.ad-promo-form button{flex:0 0 auto;padding:.6rem 1.1rem;border:none;border-radius:11px;background:#7c5cfc;color:#fff;font-weight:800;cursor:pointer}.ad-promo-form button:hover{background:#6f4ff0}.ad-table-wrap{overflow-x:auto}.ad-table{width:100%;border-collapse:collapse;font-size:.88rem}.ad-table th{text-align:left;color:#7c8bd0;font-weight:700;padding:.5rem .6rem;border-bottom:1px solid #2b3354;font-size:.78rem}.ad-table td{padding:.6rem;border-bottom:1px solid #1d2238}.ad-table tr.ad-off{opacity:.5}.ad-note{color:#7c8bd0;font-weight:500}.ad-badge{font-size:.72rem;font-weight:800;padding:3px 9px;border-radius:999px}.ad-badge.on{background:#16c79a2e;color:#36e0b4}.ad-badge.off{background:#ff6b4a29;color:#ff9f86}.ad-toggle{background:#222742;color:#cdd3f0;border:1px solid #2b3354;border-radius:9px;padding:.35rem .7rem;cursor:pointer;font-weight:700;font-size:.8rem}.ad-toggle:hover{background:#2b3354}.cp-path{position:relative;max-width:520px;margin:0 auto;display:flex;flex-direction:column;align-items:center;padding-bottom:2.5rem}.cp-path:before{content:"";position:absolute;top:70px;bottom:50px;left:50%;width:4px;transform:translate(-50%);background:repeating-linear-gradient(#ece2d2 0 9px,transparent 9px 18px);border-radius:4px;z-index:0}.cp-section{position:relative;z-index:1;width:100%;max-width:470px;display:flex;align-items:center;gap:12px;background:var(--surface);border:2px solid var(--line);border-radius:16px;padding:.7rem 1rem;margin:1.8rem 0 .6rem;box-shadow:var(--soft)}.cp-section:first-child{margin-top:.3rem}.cp-cefr{background:var(--grad-cool);color:#fff;font-weight:800;font-size:.8rem;padding:5px 11px;border-radius:10px;flex-shrink:0}.cp-section-txt b{display:block;font-family:"Baloo 2",sans-serif;font-size:1.02rem;color:var(--ink)}.cp-section-txt span{font-size:.8rem;color:var(--ink-soft)}.cp-row{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:7px;margin-bottom:1.7rem;transform:translate(var(--off, 0))}.cp-row:has(.cp-mascot){margin-top:4.6rem}.cp-node{position:relative;width:76px;height:76px;border-radius:50%;border:none;display:grid;place-items:center;color:#fff;cursor:pointer;transition:transform .15s var(--bounce),filter .15s}.cp-node:hover:not(:disabled){transform:translateY(-3px)}.cp-node:active:not(:disabled){transform:translateY(3px)}.cp-done{background:linear-gradient(145deg,#34dcab,#10b487);box-shadow:0 5px #0c8e69}.cp-current{width:88px;height:88px;background:var(--grad-warm);box-shadow:0 6px 0 var(--coral-deep)}.cp-current:after{content:"";position:absolute;top:-7px;right:-7px;bottom:-7px;left:-7px;border-radius:50%;border:3px solid var(--coral);opacity:.55;animation:cp-ring 1.8s ease-out infinite}.cp-locked{background:#ece7df;color:#b6ad9e;box-shadow:0 4px #dad3c6;cursor:default}.cp-crown{background:linear-gradient(145deg,#ffd66b,#ffc01f);box-shadow:0 5px #e0a91f}.cp-stars{display:flex;gap:1px}.cp-label{font-size:.78rem;color:var(--ink-soft);max-width:170px;text-align:center;line-height:1.25}.cp-current~.cp-label,.cp-row:has(.cp-current) .cp-label{color:var(--ink);font-weight:700}.cp-mascot{position:absolute;top:-74px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;z-index:3;pointer-events:none;animation:cp-hop 1.15s var(--bounce) infinite}.cp-here{margin-top:-4px;background:var(--ink);color:#fff;font-size:.64rem;font-weight:800;letter-spacing:.05em;padding:3px 10px;border-radius:999px;text-transform:uppercase}.cp-finish .cp-mascot{position:static;transform:none;animation:cp-hop2 1.4s var(--bounce) infinite}@keyframes cp-hop{0%,to{transform:translate(-50%) translateY(0)}32%{transform:translate(-50%) translateY(-11px)}}@keyframes cp-hop2{0%,to{transform:translateY(0)}32%{transform:translateY(-11px)}}@keyframes cp-ring{0%{transform:scale(1);opacity:.6}to{transform:scale(1.5);opacity:0}}@media(max-width:620px){.cp-path{max-width:100%}}.lh-hud{display:flex;flex-direction:row;align-items:center;flex-wrap:wrap;gap:.55rem;width:100%;padding:.5rem .6rem;background:var(--surface, #fff);border:2px solid var(--line, #f0e6d8);border-radius:999px;box-shadow:var(--pop, 0 4px 0 #e7d8c4);font-family:Plus Jakarta Sans,system-ui,sans-serif;color:var(--ink, #281f3d)}.lh-top{display:flex;align-items:center;gap:.75rem}.lh-quit{flex:0 0 auto;width:38px;height:38px;display:grid;place-items:center;border:2px solid var(--line-strong, #e7d8c4);border-radius:50%;background:var(--surface, #fff);color:var(--ink-soft, #6e6685);font-size:1.15rem;line-height:1;cursor:pointer;transition:transform .16s var(--bounce, cubic-bezier(.34,1.56,.64,1)),background .18s var(--ease, ease),color .18s var(--ease, ease),border-color .18s var(--ease, ease)}.lh-quit:hover{transform:rotate(90deg) scale(1.05);background:var(--bad, #ff5a6e);border-color:var(--bad, #ff5a6e);color:#fff}.lh-quit:active{transform:rotate(90deg) scale(.92)}.lh-progress{flex:1 1 auto;display:flex;align-items:center;gap:4px;min-width:0}.lh-seg{position:relative;flex:1 1 0;height:12px;min-width:4px;border-radius:999px;background:var(--line, #f0e6d8);overflow:hidden}.lh-seg:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;width:0;border-radius:999px;background:var(--grad-mint, linear-gradient(135deg,#16c79a,#3da5ff));transition:width .45s var(--ease, cubic-bezier(.4,0,.2,1))}.lh-seg.is-filled:after{width:100%}.lh-seg.is-current:after{width:100%;background:var(--grad-mint, linear-gradient(135deg,#16c79a,#3da5ff));animation:lh-segpulse 1.4s var(--ease, ease) infinite}@keyframes lh-segpulse{0%,to{opacity:.55;transform:scaleX(.96)}50%{opacity:1;transform:scaleX(1)}}.lh-progress.lh-progress--bar{gap:.6rem}.lh-bar{position:relative;flex:1 1 auto;height:14px;border-radius:999px;background:var(--line, #f0e6d8);overflow:hidden}.lh-bar__fill{position:absolute;top:0;right:0;bottom:0;left:0;width:0;border-radius:999px;background:var(--grad-mint, linear-gradient(135deg,#16c79a,#3da5ff));transition:width .5s var(--ease, cubic-bezier(.4,0,.2,1))}.lh-bar__pct{flex:0 0 auto;font-family:"Baloo 2",sans-serif;font-weight:800;font-size:.82rem;color:var(--ink-soft, #6e6685);min-width:2.6em;text-align:right}.lh-xp{flex:0 0 auto;display:inline-flex;align-items:center;gap:.3rem;padding:.32rem .7rem;border-radius:999px;background:var(--grad-sun, linear-gradient(135deg,#ffc93c,#ff7ab6));color:var(--ink, #281f3d);font-family:"Baloo 2",sans-serif;font-weight:800;font-size:.95rem;box-shadow:var(--pop, 0 4px 0 #e7d8c4);white-space:nowrap}.lh-xp__icon{font-size:1rem}.lh-xp__num{font-variant-numeric:tabular-nums}.lh-xp.is-bump{animation:lh-pop .4s var(--bounce, cubic-bezier(.34,1.56,.64,1))}@keyframes lh-pop{0%{transform:scale(1)}40%{transform:scale(1.22) rotate(-3deg)}to{transform:scale(1)}}.lh-bottom{display:flex;align-items:center;justify-content:space-between;gap:.75rem;min-height:28px}.lh-hearts{display:inline-flex;align-items:center;gap:2px;font-size:1.1rem;line-height:1}.lh-heart{display:inline-block;transition:transform .2s var(--bounce, cubic-bezier(.34,1.56,.64,1))}.lh-heart.is-empty{filter:grayscale(.2) opacity(.85)}.lh-heart.is-breaking{animation:lh-heartbreak .6s var(--ease, ease) both}@keyframes lh-heartbreak{0%{transform:scale(1) rotate(0)}15%{transform:scale(1.35) rotate(-12deg)}30%{transform:scale(1.1) rotate(10deg)}45%{transform:scale(1.25) rotate(-8deg)}60%{transform:scale(.9) rotate(6deg)}to{transform:scale(1) rotate(0);opacity:.85}}.lh-combo{display:inline-flex;align-items:center;gap:.3rem;padding:.3rem .75rem;border-radius:999px;color:#fff;font-family:"Baloo 2",sans-serif;font-weight:800;font-size:.9rem;letter-spacing:-.01em;white-space:nowrap;background:var(--lh-combo-color, var(--sun, #ffc93c));box-shadow:0 0 #ffc93c00,var(--pop-coral, 0 5px 0 #e8472a);transform:scale(calc(1 + (var(--lh-combo-heat, 0) * .18)));transition:transform .3s var(--bounce, cubic-bezier(.34,1.56,.64,1)),background .35s var(--ease, ease);animation:lh-comboglow 1.3s var(--ease, ease) infinite}.lh-combo__flame{display:inline-block;animation:lh-flicker .9s var(--ease, ease) infinite}.lh-combo.is-enter{animation:lh-comboin .45s var(--bounce, cubic-bezier(.34,1.56,.64,1))}@keyframes lh-comboin{0%{transform:scale(.3) translateY(6px);opacity:0}to{transform:scale(calc(1 + (var(--lh-combo-heat, 0) * .18)));opacity:1}}@keyframes lh-comboglow{0%,to{box-shadow:0 0 #ff7ab600}50%{box-shadow:0 0 14px 3px rgba(255,122,182,calc(.25 + var(--lh-combo-heat, 0) * .45))}}@keyframes lh-flicker{0%,to{transform:scale(1) rotate(-3deg)}50%{transform:scale(1.18) rotate(4deg)}}.lh-burst{position:absolute;top:8%;left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:.15rem;pointer-events:none;z-index:40;text-align:center;animation:lh-burst-rise 1.25s var(--ease, cubic-bezier(.2,.7,.3,1)) forwards}.lh-burst__xp{font-family:"Baloo 2",sans-serif;font-weight:800;font-size:2.2rem;line-height:1;color:var(--mint-deep, #0fa37e);-webkit-text-stroke:2px #fff;paint-order:stroke fill;text-shadow:0 4px 0 rgba(15,163,126,.25)}.lh-burst__label{font-family:"Baloo 2",sans-serif;font-weight:800;font-size:.95rem;color:var(--coral, #ff6b4a);background:#fff;padding:.15rem .6rem;border-radius:999px;box-shadow:var(--pop, 0 4px 0 #e7d8c4)}@keyframes lh-burst-rise{0%{transform:translate(-50%,14px) scale(.4);opacity:0}18%{transform:translate(-50%) scale(1.18);opacity:1}32%{transform:translate(-50%,-6px) scale(1);opacity:1}70%{opacity:1}to{transform:translate(-50%,-56px) scale(.95);opacity:0}}@media(max-width:760px){.lh-hud{gap:.45rem;padding:.45rem .55rem}.lh-quit{width:36px;height:36px;font-size:1.05rem}.lh-hearts{font-size:1rem;gap:1px}.lh-xp{padding:.28rem .55rem;font-size:.9rem}.lh-combo{order:5;flex:0 0 auto}}@media(max-width:480px){.lh-hud{padding:.45rem .55rem;border-radius:999px;gap:.4rem}.lh-quit{width:34px;height:34px}.lh-progress{gap:3px}.lh-seg{height:10px}.lh-hearts{font-size:.92rem}.lh-xp{font-size:.82rem;padding:.26rem .5rem}.lh-xp__icon{font-size:.9rem}.lh-combo{font-size:.82rem;padding:.26rem .6rem}.lh-burst__xp{font-size:1.8rem}}@media(prefers-reduced-motion:reduce){.lh-seg.is-current:after,.lh-combo,.lh-combo__flame,.lh-xp.is-bump,.lh-heart.is-breaking,.lh-combo.is-enter{animation:none!important}.lh-burst{animation:lh-burst-fade 1s linear forwards}@keyframes lh-burst-fade{0%{opacity:0;transform:translate(-50%)}20%,70%{opacity:1}to{opacity:0;transform:translate(-50%)}}}.lm-card{background:var(--surface);border-radius:var(--r-lg);box-shadow:var(--pop-lg);border:2px solid var(--line);font-family:Plus Jakarta Sans,sans-serif;color:var(--ink)}.lm-intro{display:flex;justify-content:center;padding:18px}.lm-intro-card{width:100%;max-width:460px;padding:24px 22px 22px;display:flex;flex-direction:column;gap:20px;animation:lm-pop-in .45s var(--bounce) both}.lm-intro-head{display:flex;align-items:center;gap:14px}.lm-kind-icon{font-size:38px;line-height:1;flex:0 0 auto;filter:drop-shadow(0 3px 0 rgba(40,31,61,.12))}.lm-intro-titles{flex:1 1 auto;min-width:0}.lm-intro-eyebrow{font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--coral-deep)}.lm-intro-title{margin:2px 0 0;font-family:"Baloo 2",sans-serif;font-weight:800;font-size:26px;line-height:1.1;color:var(--ink)}.lm-cefr{flex:0 0 auto;align-self:flex-start;background:var(--grad-cool, var(--grape));color:#fff;font-family:"Baloo 2",sans-serif;font-weight:800;font-size:14px;padding:5px 11px;border-radius:999px;box-shadow:var(--soft)}.lm-stats{display:flex;gap:10px}.lm-stat{flex:1 1 0;border-radius:var(--r-sm);padding:12px 8px;text-align:center;color:#fff;box-shadow:var(--soft);display:flex;flex-direction:column;gap:2px}.lm-stat-num{font-family:"Baloo 2",sans-serif;font-weight:800;font-size:24px;line-height:1}.lm-stat-label{font-size:11px;font-weight:600;opacity:.95}.lm-stat-coral{background:linear-gradient(160deg,#ff8a5b,var(--coral))}.lm-stat-grape{background:linear-gradient(160deg,#9a80ff,var(--grape))}.lm-stat-mint{background:linear-gradient(160deg,#2ee0b4,var(--mint))}.lm-preview-label{font-size:12px;font-weight:700;color:var(--muted);margin-bottom:8px}.lm-chips{display:flex;flex-wrap:wrap;gap:8px}.lm-chip{display:inline-flex;align-items:baseline;gap:6px;background:var(--surface-2);border:2px solid var(--line-strong);border-radius:999px;padding:6px 13px;box-shadow:var(--soft)}.lm-chip-text{font-weight:700;font-size:14px;color:var(--ink)}.lm-chip-tr{font-size:12px;color:var(--ink-soft)}.lm-chip-more{background:transparent;border-style:dashed;border-color:var(--coral);color:var(--coral-deep);font-weight:700;font-size:13px}.lm-greet{display:flex;align-items:center;gap:14px;background:var(--surface-2);border-radius:var(--r);padding:12px 16px 12px 8px;border:2px dashed var(--line-strong)}.lm-greet-line{margin:0;font-size:15px;font-weight:600;line-height:1.35;color:var(--ink)}.lm-start-btn{width:100%;border:none;cursor:pointer;font-family:"Baloo 2",sans-serif;font-weight:800;font-size:19px;color:#fff;background:linear-gradient(160deg,#ff8a5b,var(--coral-deep));border-radius:var(--r);padding:16px;box-shadow:var(--pop-coral, var(--pop));display:inline-flex;align-items:center;justify-content:center;gap:8px;transition:transform .12s var(--ease),box-shadow .12s var(--ease)}.lm-start-btn:hover{transform:translateY(-2px)}.lm-start-btn:active{transform:translateY(2px);box-shadow:var(--soft)}.lm-start-arrow{display:inline-block;transition:transform .18s var(--ease)}.lm-start-btn:hover .lm-start-arrow{transform:translate(4px)}.lm-recap{padding:18px 18px 16px;max-width:480px;margin:0 auto}.lm-recap-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px}.lm-recap-title{margin:0;font-family:"Baloo 2",sans-serif;font-weight:800;font-size:19px;color:var(--ink)}.lm-recap-count{flex:0 0 auto;font-size:12px;font-weight:700;color:var(--mint-deep);background:#16c79a1f;padding:4px 10px;border-radius:999px}.lm-recap-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px;max-height:340px;overflow-y:auto;-webkit-overflow-scrolling:touch}.lm-recap-row{display:flex;align-items:center;gap:12px;background:var(--surface-2);border:2px solid var(--line);border-radius:var(--r-sm);padding:10px 12px}.lm-recap-row.lm-missed{border-color:var(--sun);background:#ffc93c1a}.lm-recap-words{flex:1 1 auto;min-width:0}.lm-recap-main{display:flex;align-items:baseline;flex-wrap:wrap;gap:8px}.lm-recap-text{font-weight:800;font-size:16px;color:var(--ink)}.lm-recap-translit{font-size:13px;color:var(--muted);font-style:italic}.lm-recap-tag{font-size:11px;font-weight:700;color:var(--coral-deep);background:#ff6b4a24;padding:2px 8px;border-radius:999px}.lm-recap-tr{font-size:13px;color:var(--ink-soft);margin-top:2px}.lm-recap-audio{flex:0 0 auto}.lm-recap-foot{margin:12px 2px 0;font-size:13px;font-weight:600;line-height:1.35;color:var(--ink-soft)}.lm-recap-list::-webkit-scrollbar{width:8px}.lm-recap-list::-webkit-scrollbar-thumb{background:var(--line-strong);border-radius:999px}@media(max-width:480px){.lm-intro{padding:12px}.lm-intro-card{padding:18px 16px 16px;gap:16px}.lm-intro-head{gap:10px}.lm-kind-icon{font-size:32px}.lm-intro-title{font-size:22px}.lm-stats{gap:7px}.lm-stat{padding:10px 4px}.lm-stat-num{font-size:20px}.lm-stat-label{font-size:10px}.lm-start-btn{font-size:17px;padding:15px}.lm-recap{padding:14px 14px 12px}.lm-recap-list{max-height:50vh}}@keyframes lm-pop-in{0%{opacity:0;transform:scale(.94) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}@media(prefers-reduced-motion:reduce){.lm-intro-card{animation:none}.lm-start-btn,.lm-start-arrow{transition:none}.lm-start-btn:hover,.lm-start-btn:hover .lm-start-arrow{transform:none}}.es-card{background:var(--surface, #fff);border:2px solid var(--line, #f0e6d8);border-radius:var(--r-lg, 30px);box-shadow:var(--soft, 0 10px 30px rgba(40, 31, 61, .08));padding:22px 22px 26px;display:flex;flex-direction:column;gap:16px;width:100%}.es-head{display:flex;flex-direction:column;gap:10px}.es-tag{align-self:flex-start;font-family:"Baloo 2",system-ui,sans-serif;font-weight:800;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--grape, #7c5cfc);background:var(--surface-2, #fff6ec);border:2px solid var(--line-strong, #e7d8c4);border-radius:999px;padding:6px 14px;line-height:1}.es-prompt{margin:0;font-family:"Baloo 2",system-ui,sans-serif;font-weight:800;font-size:1.35rem;line-height:1.25;color:var(--ink, #281f3d)}.es-body{display:flex;flex-direction:column;gap:14px}.af-sheet{width:100%;box-sizing:border-box;padding:20px 20px calc(20px + env(safe-area-inset-bottom,0px));border-top-left-radius:var(--r-lg, 30px);border-top-right-radius:var(--r-lg, 30px);border-top:3px solid transparent;animation:af-rise .34s var(--bounce, cubic-bezier(.34, 1.56, .64, 1)) both}.af-good{background:linear-gradient(180deg,#eafaf3,#d9f6ea);border-top-color:var(--good, #16c79a);box-shadow:var(--pop-good, 0 -8px 0 rgba(15, 163, 126, .18))}.af-bad{background:linear-gradient(180deg,#fff0f2,#ffe1e6);border-top-color:var(--bad, #ff5a6e);box-shadow:var(--pop-coral, 0 -8px 0 rgba(226, 59, 80, .18))}.af-inner{display:flex;flex-direction:column;gap:16px;max-width:560px;margin:0 auto}.af-top{display:flex;align-items:center;gap:14px}.af-mark{position:relative;flex:0 0 auto;width:52px;height:52px;border-radius:50%;display:grid;place-items:center;color:#fff;font-size:1.7rem;font-weight:900;line-height:1;animation:af-pop .42s var(--bounce, cubic-bezier(.34, 1.56, .64, 1)) both}.af-good .af-mark{background:var(--good-deep, #0fa37e);box-shadow:0 6px #0fa37e59}.af-bad .af-mark{background:var(--bad-deep, #e23b50);box-shadow:0 6px #e23b5059}.af-mark:after{content:"";position:absolute;top:-6px;right:-6px;bottom:-6px;left:-6px;border-radius:50%;border:3px solid currentColor;opacity:0;animation:af-burst .6s var(--ease, ease-out) .05s both}.af-good .af-mark:after{color:var(--good, #16c79a)}.af-bad .af-mark:after{color:var(--bad, #ff5a6e)}.af-titles{display:flex;flex-direction:column;gap:2px;min-width:0}.af-headline{margin:0;font-family:"Baloo 2",system-ui,sans-serif;font-weight:800;font-size:1.5rem;line-height:1.1}.af-good .af-headline{color:var(--good-deep, #0fa37e)}.af-bad .af-headline{color:var(--bad-deep, #e23b50)}.af-sub{margin:0;font-size:.9rem;color:var(--ink-soft, #6e6685);font-weight:600}.af-lori{margin-left:auto;flex:0 0 auto;animation:af-lori-in .5s var(--bounce, cubic-bezier(.34, 1.56, .64, 1)) .08s both}.af-hint{background:#ffffffb3;border:2px solid rgba(40,31,61,.06);border-radius:var(--r, 22px);padding:14px 16px;display:flex;flex-direction:column;gap:4px}.af-hint-label{font-size:.72rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--muted, #8b84a0);margin:0 0 2px}.af-answer{font-family:"Baloo 2",system-ui,sans-serif;font-weight:800;color:var(--ink, #281f3d);line-height:1.2;overflow-wrap:break-word}.af-answer-big{font-size:clamp(1.35rem,6vw,1.7rem)}.af-answer-sm{font-size:1.1rem}.af-translit{font-size:.95rem;color:var(--muted, #8b84a0);font-style:italic;overflow-wrap:break-word}.af-meaning{font-size:1rem;color:var(--ink-soft, #6e6685);font-weight:600}.af-mini{display:flex;align-items:baseline;gap:8px;flex-wrap:wrap;padding:2px 2px 0}.af-mini .af-answer-sm{color:var(--good-deep, #0fa37e)}.af-mini .af-meaning{font-size:.92rem}.af-continue{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;cursor:pointer;width:100%;font-family:"Baloo 2",system-ui,sans-serif;font-weight:800;font-size:1.15rem;color:#fff;padding:16px 22px;border-radius:var(--r, 22px);transition:transform .12s var(--ease, ease),filter .12s var(--ease, ease)}.af-good .af-continue{background:var(--good-deep, #0fa37e);box-shadow:0 6px #086e54e6}.af-bad .af-continue{background:var(--coral-deep, #e8472a);box-shadow:0 6px #a03018e6}.af-continue:hover{filter:brightness(1.05)}.af-continue:active{transform:translateY(4px);box-shadow:0 2px #086e54e6}.af-bad .af-continue:active{box-shadow:0 2px #a03018e6}.af-continue:focus-visible{outline:3px solid var(--grape, #7c5cfc);outline-offset:3px}@keyframes af-rise{0%{transform:translateY(100%);opacity:.4}to{transform:translateY(0);opacity:1}}@keyframes af-pop{0%{transform:scale(0)}60%{transform:scale(1.18)}to{transform:scale(1)}}@keyframes af-burst{0%{transform:scale(.7);opacity:.8}to{transform:scale(1.7);opacity:0}}@keyframes af-lori-in{0%{transform:scale(0) rotate(-12deg)}to{transform:scale(1) rotate(0)}}@media(max-width:480px){.es-card{padding:16px 16px 20px;gap:14px;border-radius:var(--r, 22px)}.es-prompt{font-size:clamp(1.1rem,5.5vw,1.35rem);overflow-wrap:break-word}.af-sheet{padding:16px 14px calc(16px + env(safe-area-inset-bottom,0px))}.af-inner{gap:13px}.af-top{gap:11px}.af-mark{width:46px;height:46px;font-size:1.5rem}.af-headline{font-size:clamp(1.2rem,6vw,1.5rem)}.af-hint{padding:12px 13px}.af-answer-big{font-size:clamp(1.25rem,6.5vw,1.6rem)}.af-continue{padding:15px 18px;font-size:1.1rem}}@media(prefers-reduced-motion:reduce){.af-sheet,.af-mark,.af-mark:after,.af-lori{animation:none!important}.af-continue,.af-continue:active{transition:none}}:root{--paper: #fff9f0;--paper-2: #fff3e4;--surface: #ffffff;--surface-2: #fff6ec;--ink: #281f3d;--ink-soft: #6e6685;--muted: #8b84a0;--line: #f0e6d8;--line-strong: #e7d8c4;--coral: #ff6b4a;--coral-deep: #e8472a;--grape: #7c5cfc;--grape-deep: #5e3fe0;--sky: #3da5ff;--mint: #16c79a;--mint-deep: #0fa37e;--sun: #ffc93c;--pink: #ff7ab6;--accent: #ff6b4a;--accent-deep: #e8472a;--accent2: #7c5cfc;--good: #16c79a;--good-deep: #0fa37e;--bad: #ff5a6e;--bad-deep: #e23b50;--warn: #ffa92e;--gold: #ffc93c;--text: var(--ink);--card: var(--surface);--card2: var(--surface-2);--border: var(--line);--ring-track: #efe6f6;--grad-warm: linear-gradient(135deg, #ff8a5b 0%, #ff6b4a 55%, #ff5a8a 110%);--grad-cool: linear-gradient(135deg, #7c5cfc 0%, #3da5ff 100%);--grad-mint: linear-gradient(135deg, #16c79a 0%, #3da5ff 100%);--grad-sun: linear-gradient(135deg, #ffd84d 0%, #ffb02e 100%);--pop: 0 3px 0 var(--line-strong);--pop-lg: 0 6px 0 var(--line-strong);--pop-coral: 0 5px 0 var(--coral-deep);--pop-grape: 0 5px 0 var(--grape-deep);--pop-good: 0 5px 0 var(--good-deep);--soft: 0 10px 30px rgba(124, 92, 252, .12);--soft-lg: 0 22px 50px rgba(124, 92, 252, .16);--shadow: var(--soft);--r-sm: 14px;--r: 22px;--r-lg: 30px;--ease: cubic-bezier(.4, 0, .2, 1);--bounce: cubic-bezier(.34, 1.56, .64, 1)}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}html,body{overflow-x:hidden;max-width:100%}img,svg,video,canvas{max-width:100%;height:auto}body{font-family:Plus Jakarta Sans,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:var(--ink);background:radial-gradient(720px 520px at 88% -6%,rgba(255,122,182,.14),transparent 60%),radial-gradient(680px 520px at -8% 2%,rgba(61,165,255,.12),transparent 55%),radial-gradient(900px 700px at 50% 120%,rgba(22,199,154,.1),transparent 60%),var(--paper);background-attachment:fixed;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;letter-spacing:-.01em}h1,h2,h3,.display{font-family:"Baloo 2",Plus Jakarta Sans,sans-serif;font-weight:800;margin:0 0 .3em;letter-spacing:-.01em;line-height:1.08}button{font-family:inherit;cursor:pointer}a{color:inherit}.muted{color:var(--muted)}.small{font-size:.82rem}.loading{padding:4rem;text-align:center;color:var(--muted);font-weight:600}.loading-screen{min-height:60vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.8rem;text-align:center}.loading-msg{color:var(--ink-soft);font-weight:700;margin:0}.loading-dots{display:flex;gap:.4rem}.loading-dots span{width:9px;height:9px;border-radius:50%;background:var(--coral);animation:load-bounce 1s var(--ease) infinite}.loading-dots span:nth-child(2){background:var(--grape);animation-delay:.15s}.loading-dots span:nth-child(3){background:var(--mint);animation-delay:.3s}@keyframes load-bounce{0%,to{transform:translateY(0);opacity:.5}50%{transform:translateY(-8px);opacity:1}}.error-screen{min-height:70vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.6rem;text-align:center;padding:2rem;max-width:480px;margin:0 auto}.error-screen h2{font-size:1.6rem}.route-fade{animation:route-in .32s var(--ease) both}@keyframes route-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}.focus-mode .route-fade{animation:none}*{scrollbar-width:thin;scrollbar-color:var(--line-strong) transparent}::-webkit-scrollbar{width:11px;height:11px}::-webkit-scrollbar-thumb{background:var(--line-strong);border-radius:999px;border:3px solid transparent;background-clip:padding-box}::-webkit-scrollbar-thumb:hover{background:var(--coral);background-clip:padding-box}::selection{background:#ff6b4a40}:focus{outline:none}a:focus-visible,button:focus-visible,input:focus-visible,[tabindex]:focus-visible{outline:3px solid var(--grape);outline-offset:2px;border-radius:var(--r-sm)}.icon{display:inline-block;vertical-align:-.18em;flex:0 0 auto}.flag{display:inline-block;vertical-align:-.12em;flex:0 0 auto;border-radius:3px}.lang-tag{display:inline-block;font-size:.6rem;font-weight:800;letter-spacing:.04em;padding:.05rem .32rem;border-radius:6px;background:var(--surface-2);color:var(--ink-soft);vertical-align:.08em;margin-right:.15rem}.mic-dot{display:inline-block;width:.6em;height:.6em;border-radius:50%;background:var(--bad);margin-right:.3em;animation:pulse-dot 1s ease-in-out infinite}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.35}}.app{display:flex;flex-direction:column;min-height:100vh}.body{display:flex;flex:1}.content{flex:1;overflow-y:auto;padding:2rem clamp(1rem,4vw,3rem)}.focus-mode .content{padding:0}.topbar{height:68px;display:flex;align-items:center;justify-content:space-between;padding:0 1.5rem;background:#fffcf6d1;backdrop-filter:saturate(160%) blur(14px);-webkit-backdrop-filter:saturate(160%) blur(14px);border-bottom:2px solid var(--line);position:sticky;top:0;z-index:20}.brand{font-family:"Baloo 2",sans-serif;font-size:1.55rem;font-weight:800;color:var(--ink);text-decoration:none;letter-spacing:-.02em;display:inline-flex;align-items:center;gap:.5rem;transition:transform .2s var(--bounce)}.brand:hover{transform:rotate(-2deg) scale(1.03)}.brand-mark{background:var(--grad-warm);-webkit-background-clip:text;background-clip:text;color:transparent}.stats-cluster{display:flex;align-items:center;gap:.7rem}.stat{display:inline-flex;align-items:center;gap:.3rem;font-size:.95rem;color:var(--ink-soft);font-weight:800}.stat b{color:var(--ink);font-variant-numeric:tabular-nums}.stat.streak b{color:var(--coral)}.stat.xp b{color:#e6a700}.stat-pills{display:inline-flex;align-items:center;background:var(--surface);border:2px solid var(--line);border-radius:999px;box-shadow:var(--pop);overflow:hidden}.stat-pills .stat{padding:.36rem .74rem;font-size:.92rem}.stat-pills .stat+.stat{border-left:2px solid var(--line)}.level-chip{display:inline-grid;place-items:center;padding:2px;border-radius:50%;background:var(--surface);border:2px solid var(--line);box-shadow:var(--pop)}.level-chip .ring-label{font-size:.82rem!important;color:var(--grape-deep)}.due-pill{background:#fff;padding:.4rem .8rem;border-radius:999px;text-decoration:none;color:var(--ink-soft);border:2px solid var(--line-strong);font-weight:800;transition:.18s var(--bounce)}.due-pill:hover{transform:translateY(-2px) rotate(-2deg);border-color:var(--coral);color:var(--coral)}.stat.volume{gap:.4rem}.stat.volume .vol-icon{background:none;border:none;cursor:pointer;font-size:1.1rem;padding:0;line-height:1}.stat.volume input[type=range]{width:84px;height:6px;-moz-appearance:none;appearance:none;-webkit-appearance:none;background:var(--line-strong);border-radius:999px;cursor:pointer;outline:none}.stat.volume input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:var(--coral);border:3px solid #fff;box-shadow:0 1px 4px #0003;cursor:pointer}.stat.volume input[type=range]::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:var(--coral);border:3px solid #fff;cursor:pointer}.sidenav{width:220px;padding:1.5rem 1rem;display:flex;flex-direction:column;gap:.4rem}.nav-item{display:flex;align-items:center;gap:.7rem;padding:.75rem 1rem;border-radius:16px;color:var(--ink-soft);text-decoration:none;font-weight:800;position:relative;transition:transform .16s var(--bounce),background .18s var(--ease),color .18s var(--ease)}.nav-item span{font-size:1.2rem;transition:transform .16s var(--bounce)}.nav-item:hover{background:#fff;color:var(--ink);transform:translate(2px)}.nav-item:hover span{transform:scale(1.15) rotate(-6deg)}.nav-item.active{background:var(--grad-warm);color:#fff;box-shadow:var(--pop-coral)}.badge{margin-left:auto;background:var(--bad);color:#fff;font-size:.7rem;font-style:normal;font-weight:800;padding:.12rem .5rem;border-radius:999px;box-shadow:0 2px 0 var(--bad-deep)}.ring{position:relative;display:inline-grid;place-items:center}.ring svg{position:absolute;top:0;right:0;bottom:0;left:0}.ring-label{font-weight:800;font-family:"Baloo 2",sans-serif}.lori{display:inline-block;overflow:visible}.lori-bodygrp{animation:jelly 2.8s var(--ease) infinite;transform-origin:100px 165px}@keyframes jelly{0%,to{transform:scale(1)}30%{transform:scale(1.05,.95)}55%{transform:scale(.96,1.04)}75%{transform:scale(1.02,.98)}}.lori-arm-right.wave{animation:arm-wave .7s var(--bounce) infinite}@keyframes arm-wave{0%,to{transform:rotate(0)}50%{transform:rotate(-32deg)}}.lori-sparkle{animation:twinkle 1.4s ease-in-out infinite;transform-origin:center}@keyframes twinkle{0%,to{opacity:.4;transform:scale(.85)}50%{opacity:1;transform:scale(1.1)}}.lori-zzz{animation:zzz 2.4s ease-in-out infinite}@keyframes zzz{0%{opacity:0;transform:translateY(6px)}40%{opacity:1}to{opacity:0;transform:translateY(-10px)}}.lori-celebrate{animation:hop .6s var(--bounce) infinite}@keyframes hop{0%,to{transform:translateY(0)}40%{transform:translateY(-9px)}}.dashboard{max-width:980px;margin:0 auto}.hero{display:flex;justify-content:space-between;align-items:center;gap:2rem;margin-bottom:1.6rem;flex-wrap:wrap}.hero-greet h1{font-size:clamp(1.6rem,5.5vw,2.2rem);overflow-wrap:break-word}.hero-greet .muted{font-weight:600}.hero-goal{display:flex;align-items:center;gap:1rem;background:var(--surface);padding:1rem 1.3rem;border-radius:var(--r);border:2px solid var(--line);box-shadow:var(--pop)}.goal-text{display:flex;flex-direction:column}.goal-text b{font-family:"Baloo 2",sans-serif}.goal-done{color:var(--good);font-weight:800;font-size:.85rem}.review-cta{width:100%;text-align:left;background:var(--grad-warm);color:#fff;border:0;border-radius:var(--r);padding:1.1rem 1.4rem;font-size:1.05rem;font-weight:800;margin-bottom:1.6rem;box-shadow:var(--pop-coral);transition:transform .14s var(--bounce);position:relative;overflow:hidden}.review-cta:hover{transform:translateY(-2px)}.review-cta:active{transform:translateY(2px);box-shadow:0 2px 0 var(--coral-deep)}.continue-cta{width:100%;display:flex;align-items:center;gap:1rem;text-align:left;background:var(--grad-cool);color:#fff;border:0;border-radius:var(--r);padding:1.1rem 1.3rem;margin-bottom:1rem;box-shadow:var(--pop-grape);transition:transform .14s var(--bounce)}.continue-cta:hover{transform:translateY(-2px)}.continue-cta:active{transform:translateY(2px);box-shadow:0 2px 0 var(--grape-deep)}.continue-cta .cc-icon{font-size:1.2rem;display:grid;place-items:center;width:42px;height:42px;border-radius:50%;background:#ffffff38;flex:0 0 auto}.continue-cta .cc-text{display:flex;flex-direction:column;flex:1;min-width:0}.continue-cta .cc-text b{font-family:"Baloo 2",sans-serif;font-size:1.05rem}.continue-cta .cc-text span{font-size:.9rem;opacity:.92;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.continue-cta .cc-go{font-size:1.4rem;font-weight:800;flex:0 0 auto}.lang-switch{display:flex;gap:.7rem;margin-bottom:1.6rem;flex-wrap:wrap}.lang-chip{display:flex;align-items:center;gap:.5rem;padding:.6rem 1.05rem;border-radius:999px;background:#fff;border:2px solid var(--line-strong);color:var(--ink-soft);font-weight:800;position:relative;box-shadow:var(--pop);transition:transform .16s var(--bounce),box-shadow .18s var(--ease)}.lang-chip .flag{font-size:1.3rem}.lang-chip.on{background:var(--grad-cool);color:#fff;border-color:transparent;box-shadow:var(--pop-grape)}.lang-chip:hover{transform:translateY(-3px) rotate(-1deg)}.lang-chip:active{transform:translateY(0)}.chip-due{position:absolute;top:-7px;right:-3px;background:var(--bad);color:#fff;font-style:normal;font-size:.68rem;font-weight:800;padding:.08rem .42rem;border-radius:999px;box-shadow:0 2px 0 var(--bad-deep)}.course-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:1rem}.course-head h2{font-size:1.5rem}.unit{margin-bottom:1.8rem}.unit-head{display:flex;gap:.8rem;align-items:center;margin-bottom:.9rem}.cefr{background:var(--grad-sun);color:#5a3d00;font-weight:800;padding:.28rem .6rem;border-radius:10px;font-size:.78rem;box-shadow:0 3px #e0a020;letter-spacing:.02em}.unit-head h3{font-size:1.15rem}.unit-head p{margin:0;font-size:.85rem}.lesson-path{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:.9rem}.lesson-node{display:flex;flex-direction:column;gap:.35rem;align-items:flex-start;text-align:left;background:var(--surface);border:2px solid var(--line);border-radius:20px;padding:1.1rem;color:var(--ink);box-shadow:var(--pop);transition:transform .16s var(--bounce),box-shadow .2s var(--ease),border-color .2s var(--ease)}.lesson-node:hover{transform:translateY(-4px);border-color:var(--coral);box-shadow:var(--pop-lg)}.lesson-node:active{transform:translateY(0)}.lesson-node.done{border-color:var(--good);background:linear-gradient(180deg,#effbf6,#fff)}.node-icon{font-size:1.7rem}.lesson-node.done .node-icon{color:var(--good)}.node-title{font-weight:800}.node-count{font-size:.78rem;color:var(--muted);font-weight:700}.node-stars{color:var(--gold);letter-spacing:2px}.btn{background:#fff;color:var(--ink);border:2px solid var(--line-strong);border-radius:16px;padding:.72rem 1.3rem;font-weight:800;box-shadow:var(--pop);transition:transform .14s var(--bounce),box-shadow .18s var(--ease),border-color .18s var(--ease)}.btn:hover{transform:translateY(-2px);border-color:var(--coral)}.btn:active{transform:translateY(1px);box-shadow:0 1px 0 var(--line-strong)}.btn.primary{background:var(--grad-warm);border-color:transparent;color:#fff;box-shadow:var(--pop-coral)}.btn.primary:hover{transform:translateY(-2px);filter:brightness(1.05)}.btn.primary:active{transform:translateY(2px);box-shadow:0 2px 0 var(--coral-deep)}.btn.big{padding:.95rem 2.1rem;font-size:1.08rem}.lesson-runner,.review-runner{display:flex;flex-direction:column;min-height:calc(100vh - 68px)}.runner-head{display:flex;align-items:center;gap:1rem;padding:1.1rem 1.5rem}.quit{background:none;border:0;color:var(--muted);font-size:1.5rem}.quit:hover{color:var(--bad)}.prog-bar{flex:1;height:16px;background:#fff;border:2px solid var(--line-strong);border-radius:999px;overflow:hidden}.prog-fill{height:100%;background:var(--grad-mint);transition:width .4s var(--ease);border-radius:999px}.hearts-live,.review-left{font-size:.95rem;color:var(--ink-soft);white-space:nowrap;font-weight:800}.runner-stage{flex:1;display:grid;place-items:center;padding:1.5rem;overflow-y:auto}.ex{width:min(580px,92vw);background:var(--surface);border:2px solid var(--line);border-radius:var(--r-lg);padding:2.2rem;text-align:center;box-shadow:var(--soft-lg);animation:pop .3s var(--bounce)}@keyframes pop{0%{opacity:0;transform:scale(.94) translateY(12px)}to{opacity:1;transform:none}}.ex-tag{display:inline-block;background:var(--grad-cool);color:#fff;font-weight:800;font-size:.72rem;padding:.25rem .7rem;border-radius:999px;margin-bottom:.9rem;letter-spacing:.04em;text-transform:uppercase}.ex-prompt{font-size:1.2rem;font-weight:800;margin-bottom:1.2rem;font-family:"Baloo 2",sans-serif;overflow-wrap:break-word}.ex-sub{color:var(--muted);margin-top:-.7rem;margin-bottom:1rem;font-size:.85rem;font-weight:600}.target-big{font-size:clamp(1.9rem,8vw,2.6rem);font-weight:800;letter-spacing:-.02em;font-family:"Baloo 2",sans-serif;overflow-wrap:break-word}.translit{color:var(--grape);font-size:1.1rem;margin-top:.2rem;font-weight:700;overflow-wrap:break-word}.ipa{color:var(--muted);font-style:italic;overflow-wrap:break-word}.play-row{margin:1.3rem 0;display:flex;justify-content:center;gap:.6rem}.meanings{display:flex;gap:1.2rem;justify-content:center;flex-wrap:wrap;color:var(--ink);margin:.6rem 0;font-weight:700}.meanings.small{font-size:.85rem;color:var(--muted);font-weight:600}.note{background:var(--surface-2);border-left:4px solid var(--gold);padding:.8rem 1rem;border-radius:12px;text-align:left;color:var(--ink-soft);font-size:.9rem;margin:1rem 0;font-weight:600}.options{display:grid;gap:.7rem;margin-top:1rem}.script-options,.pair-options{grid-template-columns:1fr 1fr}.option{background:#fff;border:2px solid var(--line-strong);border-radius:16px;padding:1rem;display:flex;flex-direction:column;gap:.2rem;color:var(--ink);font-size:1rem;font-weight:700;min-width:0;overflow-wrap:break-word;box-shadow:var(--pop);transition:transform .14s var(--bounce),box-shadow .18s var(--ease),border-color .18s var(--ease)}.option:hover:not(:disabled){border-color:var(--grape);transform:translateY(-3px)}.option:active:not(:disabled){transform:translateY(0)}.option.correct{border-color:var(--good);background:#e9fbf4;box-shadow:var(--pop-good)}.option.wrong{border-color:var(--bad);background:#ffeef0;box-shadow:0 4px 0 var(--bad-deep)}.opt-en{color:var(--muted);font-size:.85rem;font-weight:600}.opt-target{font-size:1.35rem;font-weight:800;font-family:"Baloo 2",sans-serif}.opt-translit{color:var(--grape);font-size:.85rem;font-weight:700}.pair-opt{position:relative}.mini-play{position:absolute;top:.5rem;right:.6rem;font-size:.9rem}.audio-btn-group{display:inline-flex;gap:.5rem;align-items:center}.audio-btn{background:var(--grad-cool);border:0;color:#fff;border-radius:999px;padding:.7rem 1.2rem;font-size:1.1rem;font-weight:800;display:inline-flex;align-items:center;gap:.4rem;box-shadow:var(--pop-grape);transition:transform .14s var(--bounce)}.audio-btn:hover{transform:translateY(-2px) scale(1.04)}.audio-btn:active{transform:translateY(2px);box-shadow:0 2px 0 var(--grape-deep)}.audio-btn.playing{animation:pulse 1s infinite}.audio-btn.slow{background:#fff;color:var(--grape);border:2px solid var(--line-strong);box-shadow:var(--pop)}.size-lg .audio-btn,.audio-btn.size-lg{font-size:1.5rem;padding:1rem 1.7rem}.size-sm .audio-btn{font-size:.95rem;padding:.5rem .9rem}.audio-label{font-size:.85rem;font-weight:800}.audio-btn.slow .slow-x{font-size:.74rem;font-weight:800;font-variant-numeric:tabular-nums}@keyframes pulse{0%,to{box-shadow:0 0 #7c5cfc73}50%{box-shadow:0 0 0 14px #7c5cfc00}}.mic-btn{background:var(--grad-warm);color:#fff;border:0;border-radius:999px;padding:.9rem 1.7rem;font-size:1.05rem;font-weight:800;margin-top:1rem;box-shadow:var(--pop-coral);transition:transform .14s var(--bounce)}.mic-btn:hover:not(:disabled){transform:translateY(-2px) scale(1.03)}.mic-btn.listening{animation:pulse 1s infinite}.mic-btn.unsupported{background:#fff;color:var(--muted);border:2px solid var(--line-strong);box-shadow:var(--pop)}.mic-btn:disabled{opacity:.7}.mic-wrap{display:flex;flex-direction:column;align-items:center;gap:.5rem}.mic-hint{font-size:.8rem;color:var(--muted);max-width:360px;font-weight:600}.mic-error{font-size:.85rem;color:#b15a00;background:#fff3e0;border:2px solid #ffd699;border-radius:12px;padding:.5rem .8rem;max-width:380px;font-weight:600}.speak-result{margin-top:1.2rem}.speak-result.inline{display:flex;align-items:center;gap:1rem;justify-content:center}.score-badge{display:inline-block;font-size:1.7rem;font-weight:800;padding:.3rem 1.1rem;border-radius:14px;font-family:"Baloo 2",sans-serif}.score-badge.great{color:var(--good-deep);background:#e9fbf4}.score-badge.ok{color:#c98a00;background:#fff6db}.score-badge.low{color:var(--bad-deep);background:#ffeef0}.heard{color:var(--ink-soft);margin-top:.4rem;font-weight:600}.heard.muted{font-style:italic;color:var(--muted)}.word-marks{display:flex;flex-wrap:wrap;gap:.4rem;justify-content:center;margin-top:.6rem}.wm{padding:.15rem .55rem;border-radius:8px;font-weight:800}.wm.ok{background:#e9fbf4;color:var(--good-deep)}.wm.bad{background:#ffeef0;color:var(--bad-deep)}.ex-actions{margin-top:1.2rem}.dialog-track{display:flex;flex-direction:column;gap:.6rem;margin:1rem 0}.bubble{max-width:85%;padding:.75rem 1rem;border-radius:18px;text-align:left}.bubble.them{align-self:flex-start;background:var(--surface-2);border:2px solid var(--line);border-bottom-left-radius:5px}.bubble.me{align-self:flex-end;background:var(--grad-cool);color:#fff;border-bottom-right-radius:5px}.bubble.active{outline:3px solid var(--coral);outline-offset:1px}.bubble-target{font-size:1.15rem;font-weight:800}.bubble-translit{font-size:.82rem;opacity:.85}.bubble-trans{font-size:.78rem;opacity:.85;margin-top:.3rem}.dialog-controls{display:flex;flex-direction:column;align-items:center;gap:.8rem;margin-top:1rem}.your-turn{color:var(--coral);font-weight:800}.link-btn{background:none;border:0;color:var(--muted);text-decoration:underline;font-size:.85rem;margin-top:.8rem;font-weight:600}.link-btn:hover{color:var(--ink)}.optional-mic{margin-top:1rem;display:flex;flex-direction:column;align-items:center;gap:.6rem}.lesson-end,.review-empty{width:min(540px,92vw);margin:3rem auto;text-align:center;background:var(--surface);border:2px solid var(--line);border-radius:var(--r-lg);padding:2.6rem;box-shadow:var(--soft-lg)}.big-emoji{font-size:4rem}.lesson-end h1,.lesson-end h2,.review-empty h2{font-size:clamp(1.45rem,6vw,1.9rem)}.stars{font-size:2.2rem;color:var(--gold);letter-spacing:6px;margin:.5rem 0}.end-stats{display:flex;justify-content:center;gap:2rem;margin:1.5rem 0}.end-stat{display:flex;flex-direction:column}.end-stat b{font-size:1.9rem;color:var(--coral);font-family:"Baloo 2",sans-serif}.end-stat span{color:var(--muted);font-size:.85rem;font-weight:600}.srs-note{color:#c98a00;font-weight:700}.end-actions{display:flex;gap:1rem;justify-content:center;margin-top:1rem;flex-wrap:wrap}.flashcard{width:min(540px,92vw);margin:auto;background:var(--surface);border:2px solid var(--line);border-radius:var(--r-lg);padding:2.6rem 2rem;text-align:center;box-shadow:var(--soft-lg);position:relative}.card-flag{position:absolute;top:1rem;left:1.2rem;font-size:1.7rem}.card-prompt{color:var(--muted);margin-bottom:1.2rem;font-weight:700}.reveal{margin-top:1.5rem}.ratings{display:grid;grid-template-columns:repeat(4,1fr);gap:.6rem;margin-top:1.5rem}.rate-btn{display:flex;flex-direction:column;gap:.15rem;border:0;border-radius:14px;padding:.85rem .3rem;color:#fff;font-weight:800;transition:transform .14s var(--bounce)}.rate-btn span{font-size:.72rem;font-weight:600;opacity:.9}.rate-btn:hover{transform:translateY(-3px)}.rate-btn:active{transform:translateY(1px)}.rate-btn.again{background:var(--bad);box-shadow:0 4px 0 var(--bad-deep)}.rate-btn.hard{background:var(--warn);color:#4a2e00;box-shadow:0 4px #d98800}.rate-btn.good{background:var(--good);box-shadow:var(--pop-good)}.rate-btn.easy{background:var(--grape);box-shadow:var(--pop-grape)}.stats-page{max-width:940px;margin:0 auto}.stats-page h1{font-size:1.9rem}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin:1.5rem 0}.kpi{background:var(--surface);border:2px solid var(--line);border-radius:var(--r);padding:1.3rem;display:flex;flex-direction:column;gap:.15rem;box-shadow:var(--pop);transition:transform .16s var(--bounce)}.kpi:hover{transform:translateY(-3px)}.kpi-icon{font-size:1.5rem}.kpi-value{font-size:1.9rem;color:var(--coral);font-family:"Baloo 2",sans-serif;font-weight:800}.kpi-label{color:var(--ink-soft);font-size:.85rem;font-weight:700}.kpi-sub{color:var(--muted);font-size:.75rem;font-weight:600}.panel{background:var(--surface);border:2px solid var(--line);border-radius:var(--r);padding:1.6rem;margin-bottom:1.5rem;box-shadow:var(--pop)}.bar-chart{display:flex;align-items:flex-end;gap:5px;height:160px;margin-top:1rem}.bar-col{flex:1;display:flex;flex-direction:column;justify-content:flex-end;align-items:center;height:100%}.bar{width:72%;min-height:3px;background:var(--grad-mint);border-radius:6px 6px 0 0;transition:height .5s var(--bounce)}.bar-x{font-size:.6rem;color:var(--muted);margin-top:.3rem;font-weight:700}.achv-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:1rem;margin-top:1rem}.achv{display:flex;flex-direction:column;align-items:center;gap:.4rem;padding:1.1rem;border-radius:18px;background:var(--surface);border:2px solid var(--line);text-align:center;box-shadow:var(--pop);transition:transform .16s var(--bounce)}.achv:hover{transform:translateY(-3px) rotate(-2deg)}.achv.locked{opacity:.4;filter:grayscale(1)}.achv.earned{border-color:var(--gold);background:linear-gradient(180deg,#fffae8,#fff)}.achv-icon{font-size:2.1rem}.achv-name{font-size:.78rem;font-weight:700}.settings-page{max-width:740px;margin:0 auto}.settings-page h1{font-size:1.9rem}.settings-page h3{margin-top:1.5rem}.goal-options{display:flex;gap:.6rem;margin:1rem 0;flex-wrap:wrap}.goal-opt{background:#fff;border:2px solid var(--line-strong);border-radius:14px;padding:.72rem 1.3rem;color:var(--ink);font-weight:800;box-shadow:var(--pop);transition:transform .14s var(--bounce)}.goal-opt:hover{transform:translateY(-2px)}.goal-opt.on{border-color:transparent;background:var(--grad-warm);color:#fff;box-shadow:var(--pop-coral)}.voice-test{display:flex;flex-direction:column;gap:.7rem;margin:1rem 0}.voice-row{display:flex;align-items:center;gap:1rem}.voice-row>span:first-child{width:140px;font-weight:700}.run-tip{color:var(--ink-soft);margin-top:1rem;font-weight:600}code{background:var(--surface-2);padding:.15rem .45rem;border-radius:8px;color:var(--grape-deep);font-weight:700}.ok{color:var(--good-deep)}.warn{color:#b15a00}.stories-page{max-width:940px;margin:0 auto}.stories-page h1{font-size:1.9rem}.story-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:1.1rem;margin-top:1rem}.story-card{text-align:left;background:var(--surface);border:2px solid var(--line);border-radius:20px;padding:1.3rem;color:var(--ink);display:flex;flex-direction:column;gap:.3rem;box-shadow:var(--pop);transition:transform .16s var(--bounce),box-shadow .2s var(--ease),border-color .2s var(--ease)}.story-card:hover{transform:translateY(-4px) rotate(-1deg);border-color:var(--mint);box-shadow:var(--pop-lg)}.story-card.done{border-color:var(--good);background:linear-gradient(180deg,#effbf6,#fff)}.story-top{display:flex;justify-content:space-between;align-items:center}.story-play{color:var(--mint);font-size:1.2rem}.story-check{color:var(--good);font-weight:800;font-size:.8rem}.story-title{font-size:1.15rem;font-weight:800;font-family:"Baloo 2",sans-serif}.story-titletr{font-size:.85rem;color:var(--ink-soft);font-weight:600}.story-topic{font-size:.78rem;color:var(--mint-deep);margin-top:.3rem;font-weight:700}.story-runner{display:flex;flex-direction:column;min-height:calc(100vh - 68px)}.story-head-title{font-weight:800;display:flex;align-items:center;gap:.5rem;font-family:"Baloo 2",sans-serif}.story-stage{flex:1;overflow-y:auto;padding:1.5rem;max-width:780px;margin:0 auto;width:100%}.story-controls{display:flex;gap:.8rem;justify-content:center;margin-bottom:1.2rem;position:sticky;top:0}.story-lines{display:flex;flex-direction:column;gap:.6rem;margin-bottom:1.5rem}.story-line{display:flex;gap:.8rem;padding:.9rem;border-radius:16px;background:var(--surface);border:2px solid var(--line);transition:.18s var(--ease)}.story-line.active{border-color:var(--coral);background:var(--surface-2);transform:scale(1.01)}.sl-controls{display:flex;flex-direction:column;gap:.3rem}.sl-controls .audio-btn{padding:.4rem .6rem;font-size:.9rem}.sl-text{flex:1}.sl-target{font-size:1.25rem;font-weight:800}.sl-translit{color:var(--grape);font-size:.9rem;font-weight:700}.sl-meaning{color:var(--ink-soft);font-size:.85rem;margin-top:.3rem;font-weight:600}.story-stage.quiz{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}.story-stage.quiz .options{width:min(520px,92vw)}.quiz-progress{color:var(--muted);margin-bottom:1rem;font-weight:700}.games-page{max-width:880px;margin:0 auto}.games-page h1{font-size:1.9rem}.games-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.2rem;margin-top:1.5rem}.game-card{text-align:left;background:var(--surface);border:2px solid var(--line);border-radius:24px;padding:1.6rem;color:var(--ink);display:flex;flex-direction:column;gap:.5rem;box-shadow:var(--pop);transition:transform .16s var(--bounce),box-shadow .2s var(--ease),border-color .2s var(--ease)}.game-card:hover{transform:translateY(-5px) rotate(-1deg);border-color:var(--grape);box-shadow:var(--pop-lg)}.game-icon{font-size:2.8rem}.game-tag{align-self:flex-start;background:var(--grad-cool);color:#fff;font-weight:800;font-size:.68rem;padding:.18rem .6rem;border-radius:999px;letter-spacing:.04em;text-transform:uppercase}.game-title{font-size:1.35rem;font-weight:800;font-family:"Baloo 2",sans-serif}.game-desc{font-size:.9rem;color:var(--ink-soft);font-weight:600}.game-play{color:var(--grape);font-weight:800;margin-top:.3rem}.match-runner{display:flex;flex-direction:column;min-height:calc(100vh - 68px)}.match-stat{color:var(--ink-soft);font-weight:800}.match-langs{display:flex;gap:.5rem;justify-content:center;padding:.5rem}.match-langs .lang-chip{padding:.4rem .75rem}.match-board{flex:1;display:flex;gap:2rem;justify-content:center;padding:1.5rem;overflow-y:auto}.match-col{display:flex;flex-direction:column;gap:.8rem;width:min(260px,42vw)}.col-head{text-align:center;color:var(--ink-soft);font-weight:800;margin-bottom:.3rem}.match-card{padding:1.1rem;border-radius:16px;border:2px solid var(--line-strong);background:#fff;color:var(--ink);font-size:1.05rem;font-weight:800;min-height:56px;box-shadow:var(--pop);transition:transform .14s var(--bounce),box-shadow .18s var(--ease),border-color .18s var(--ease)}.match-card.audio{font-size:1.5rem}.match-card:hover:not(:disabled){border-color:var(--grape);transform:translateY(-3px)}.match-card.sel{border-color:var(--coral);background:var(--surface-2);box-shadow:0 0 0 4px #ff6b4a38,var(--pop)}.match-card.matched{border-color:var(--good);background:#e9fbf4;color:var(--good-deep);cursor:default}.match-card.wrong{border-color:var(--bad);background:#ffeef0;animation:shake .35s}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-7px)}75%{transform:translate(7px)}}.match-card .mc-word{display:flex;flex-direction:column;gap:.1rem}.match-card .mc-target{font-weight:800}.match-card .mc-translit{font-size:.78rem;color:var(--grape);font-weight:700}.match-setup{max-width:620px;margin:1rem auto;padding:1rem clamp(1rem,4vw,2rem) 3rem;text-align:center;display:flex;flex-direction:column;align-items:center;gap:.4rem}.match-setup h2{font-size:1.6rem}.match-setup>.btn.primary{margin-top:1.4rem}.ms-section{width:100%;margin-top:1.1rem;text-align:left}.ms-label{font-weight:800;color:var(--ink-soft);font-size:.85rem;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.04em}.ms-modes{display:grid;grid-template-columns:repeat(2,1fr);gap:.6rem}.ms-mode{display:flex;align-items:center;gap:.5rem;background:#fff;border:2px solid var(--line-strong);border-radius:16px;padding:.8rem 1rem;font-weight:800;color:var(--ink);box-shadow:var(--pop);transition:transform .14s var(--bounce),border-color .18s var(--ease),background .18s var(--ease)}.ms-mode:hover{transform:translateY(-2px)}.ms-mode.on{border-color:transparent;background:var(--grad-cool);color:#fff;box-shadow:var(--pop-grape)}.ms-levels{display:flex;flex-wrap:wrap;gap:.5rem}.ms-level{background:#fff;border:2px solid var(--line-strong);border-radius:999px;padding:.45rem 1rem;font-weight:800;color:var(--ink-soft);box-shadow:var(--pop);transition:transform .14s var(--bounce)}.ms-level:hover{transform:translateY(-2px)}.ms-level.on{border-color:transparent;background:var(--grad-warm);color:#fff;box-shadow:var(--pop-coral)}.match-setup .match-langs{flex-wrap:wrap;justify-content:flex-start}.match-session-hud{display:flex;align-items:center;gap:.8rem;flex:1;justify-content:center}.match-session-hud .match-stat{display:inline-flex;align-items:center;gap:.3rem}.match-timer{display:inline-flex;align-items:center;gap:.3rem;font-family:"Baloo 2",sans-serif;font-weight:800;color:var(--ink);background:var(--surface-2);border-radius:999px;padding:.2rem .7rem}.match-timer.low{color:#fff;background:var(--bad);animation:pulse-dot .8s ease-in-out infinite}.match-mode-tag{color:var(--grape)}.conv-runner{display:flex;flex-direction:column;min-height:calc(100vh - 68px)}.conv-stage{flex:1;display:flex;flex-direction:column;max-width:740px;margin:0 auto;width:100%;overflow:hidden}.conv-scene{text-align:center;color:var(--mint-deep);background:var(--surface);border:2px solid var(--line);border-radius:16px;padding:.8rem;margin:1rem;font-weight:700;box-shadow:var(--pop)}.conv-thread{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:.7rem}.conv-thread .bubble{max-width:85%;padding:.85rem 1rem;border-radius:18px}.conv-thread .bubble.them{align-self:flex-start;background:var(--surface-2);border:2px solid var(--line);border-bottom-left-radius:5px}.conv-thread .bubble.me{align-self:flex-end;background:var(--grad-cool);color:#fff;border-bottom-right-radius:5px}.bubble-who{font-size:.72rem;color:var(--mint-deep);font-weight:800;margin-bottom:.2rem}.bubble.me .bubble-who{color:#ffffffd9}.conv-replies{padding:1rem;display:flex;flex-direction:column;gap:.6rem;border-top:2px solid var(--line)}.reply-row{display:flex;gap:.5rem;align-items:stretch}.reply-btn{flex:1;text-align:left;background:#fff;border:2px solid var(--line-strong);border-radius:16px;padding:.85rem 1rem;color:var(--ink);display:flex;flex-direction:column;gap:.15rem;box-shadow:var(--pop);transition:transform .14s var(--bounce),border-color .18s var(--ease)}.reply-btn:hover{border-color:var(--coral);transform:translateY(-2px)}.reply-target{font-size:1.1rem;font-weight:800}.reply-translit{color:var(--grape);font-size:.82rem;font-weight:700}.reply-tr{color:var(--muted);font-size:.82rem;font-weight:600}.conv-hud{display:flex;align-items:center;flex-wrap:wrap;gap:.5rem;margin:0 1rem .2rem;padding:.5rem .7rem;background:var(--surface);border:2px solid var(--line);border-radius:999px;box-shadow:var(--pop)}.conv-stat{font-weight:800;color:var(--ink-soft);font-size:.9rem}.conv-stat b{color:var(--ink)}.conv-combo{font-family:"Baloo 2",sans-serif;font-weight:800;color:#fff;font-size:.85rem;background:var(--grad-warm);padding:.15rem .6rem;border-radius:999px;box-shadow:0 3px 0 var(--coral-deep);animation:hop .6s var(--bounce) infinite}.conv-mic-toggle{margin-left:auto;font-weight:800;font-size:.85rem;border-radius:999px;padding:.4rem .85rem;border:2px solid var(--line-strong);background:#fff;color:var(--ink-soft);box-shadow:var(--pop);transition:transform .14s var(--bounce),background .18s var(--ease),color .18s var(--ease),border-color .18s var(--ease)}.conv-mic-toggle:hover:not(:disabled){transform:translateY(-1px)}.conv-mic-toggle.on{background:var(--grad-warm);color:#fff;border-color:transparent;box-shadow:var(--pop-coral)}.conv-mic-toggle:disabled{opacity:.5;cursor:not-allowed}.conv-flash{align-self:center;margin:.2rem auto;padding:.3rem .9rem;border-radius:999px;font-weight:800;font-family:"Baloo 2",sans-serif;animation:slidein .3s var(--bounce)}.conv-flash.good{background:#e9fbf4;color:var(--good-deep)}.conv-flash.bad{background:#fff3e0;color:#b15a00}.bubble-pron{margin-top:.3rem;font-size:.8rem;font-weight:800}.bubble.me .bubble-pron.great{color:#d9fbe9}.bubble-pron.great{color:var(--good-deep)}.bubble-pron.ok{color:#ffe9a8}.bubble-pron.low{color:#ffd9df}.reply-mic{background:#fff;border:2px solid var(--line-strong);border-radius:16px;padding:.8rem .9rem;box-shadow:var(--pop);display:flex;flex-direction:column;gap:.6rem}.reply-mic.active{border-color:var(--coral);box-shadow:var(--pop-coral)}.reply-mic-head{display:flex;align-items:center;gap:.6rem}.reply-mic-text{flex:1;display:flex;flex-direction:column;gap:.1rem;min-width:0}.reply-mic-attempt{display:flex;flex-direction:column;gap:.6rem;align-items:center}.reply-mic-actions{display:flex;gap:.6rem;flex-wrap:wrap;justify-content:center}.mic-listening{font-weight:800;color:var(--coral)}.toasts{position:fixed;top:84px;right:20px;display:flex;flex-direction:column;gap:.7rem;z-index:100}.toast{display:flex;gap:.7rem;align-items:center;background:var(--surface);border:2px solid var(--line);border-radius:16px;padding:.9rem 1.1rem;box-shadow:var(--soft-lg);animation:slidein .4s var(--bounce);min-width:230px}.toast-achievement{border-color:var(--gold)}.toast-level{border-color:var(--grape)}.toast-icon{font-size:1.7rem}.toast-title{font-weight:800;font-family:"Baloo 2",sans-serif}.toast-body{color:var(--ink-soft);font-size:.85rem;font-weight:600}@keyframes slidein{0%{opacity:0;transform:translate(50px)}to{opacity:1;transform:none}}.confetti{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden;z-index:90}.confetti-bit{position:absolute;top:-16px;opacity:0;animation-name:confetti-fall;animation-timing-function:cubic-bezier(.3,.6,.4,1);animation-fill-mode:forwards}@keyframes confetti-fall{0%{opacity:0;transform:translateY(-10px) rotate(0)}10%{opacity:1}to{opacity:0;transform:translate(var(--drift, 0),102vh) rotate(var(--rot, 360deg))}}.focus-mode .lesson-runner,.focus-mode .story-runner,.focus-mode .conv-runner,.focus-mode .match-runner{min-height:100vh;min-height:100dvh}.lesson-runner>.lh-hud{width:auto;margin:.9rem clamp(.7rem,3vw,1.4rem) .2rem}.lesson-runner.intro-mode{justify-content:center;align-items:center;padding:1.5rem}.lesson-fb{position:fixed;left:0;right:0;bottom:0;z-index:60;display:flex;justify-content:center;pointer-events:none}.lesson-fb>*{pointer-events:auto;width:min(640px,100%)}.bottomnav{display:none}@media(max-width:760px){.sidenav{display:none}.hero{flex-direction:column;align-items:stretch;gap:1rem}.hero-greet h1{font-size:clamp(1.5rem,6vw,1.9rem)}.hero-goal{width:100%}.content{padding:1.25rem 1rem calc(78px + env(safe-area-inset-bottom,0px))}.topbar{padding:0 .85rem;padding-top:env(safe-area-inset-top,0px);height:auto;min-height:62px;gap:.5rem;flex-wrap:wrap}.stats-cluster{gap:.55rem .7rem;flex-wrap:wrap;justify-content:flex-end;row-gap:.3rem}.brand{font-size:1.35rem}.lesson-path{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.story-grid{grid-template-columns:repeat(auto-fill,minmax(170px,1fr))}.games-grid{grid-template-columns:1fr}.kpi-grid{grid-template-columns:repeat(auto-fit,minmax(130px,1fr))}.achv-grid{grid-template-columns:repeat(auto-fill,minmax(92px,1fr))}.runner-head{padding:.9rem 1rem;gap:.7rem}.runner-stage{padding:1rem .85rem}.ex{width:100%;max-width:100%;padding:1.5rem 1.2rem;border-radius:var(--r)}.options{grid-template-columns:1fr}.script-options,.pair-options{grid-template-columns:1fr 1fr}.lesson-end,.review-empty,.flashcard{width:100%;max-width:100%;padding:1.8rem 1.3rem}.end-stats{gap:1.2rem}.match-board{gap:.7rem;padding:1rem .7rem}.match-col{width:min(48vw,220px)}.nav-item,.btn,.lang-chip,.goal-opt,.due-pill,.audio-btn,.mic-btn,.option,.rate-btn,.reply-btn,.match-card{min-height:44px}.quit{min-width:44px;min-height:44px;display:inline-flex;align-items:center;justify-content:center}.toasts{top:auto;left:12px;right:12px;bottom:calc(82px + env(safe-area-inset-bottom,0px))}.toast{min-width:0;width:100%}.bottomnav{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:30;padding:.4rem .4rem calc(.4rem + env(safe-area-inset-bottom,0px));background:#fffcf6f0;backdrop-filter:saturate(160%) blur(14px);-webkit-backdrop-filter:saturate(160%) blur(14px);border-top:2px solid var(--line);justify-content:space-around}.focus-mode .bottomnav{display:none}.bottomnav .nav-item{flex-direction:column;gap:.1rem;padding:.35rem .4rem;font-size:.62rem;font-weight:800;flex:1;justify-content:center;text-align:center;border-radius:14px;min-height:50px;min-width:0}.bottomnav .nav-item span{font-size:1.5rem}.bottomnav .nav-item:hover{transform:none;background:transparent}.bottomnav .nav-item.active{background:transparent;color:var(--coral);box-shadow:none}.bottomnav .badge{position:absolute;top:.05rem;right:50%;margin-right:-1.2rem}}@media(max-width:480px){.content{padding:1rem .8rem calc(78px + env(safe-area-inset-bottom,0px))}.course-head{flex-wrap:wrap;gap:.4rem}.course-head h2{font-size:1.3rem}.level-chip{display:none}.stat{font-size:.88rem}.stat-pills .stat{padding:.3rem .55rem}.stat.volume input[type=range]{width:60px}.story-grid,.lesson-path{grid-template-columns:1fr}.kpi-grid,.ratings{grid-template-columns:1fr 1fr}.match-board{flex-direction:column;align-items:stretch;gap:1rem}.match-col{width:100%}.match-col:first-child{padding-bottom:1rem;border-bottom:2px dashed var(--line-strong)}.end-stats{flex-wrap:wrap;gap:.8rem 1.5rem}.ex{padding:1.3rem 1rem}.target-big{font-size:clamp(1.7rem,9vw,2.2rem)}.size-lg .audio-btn,.audio-btn.size-lg{font-size:1.3rem;padding:.85rem 1.3rem}}@media(max-width:380px){.stat.volume input[type=range]{display:none}.brand{font-size:1.2rem}.stats-cluster{gap:.45rem}}@media(min-width:761px){.topbar{flex-wrap:nowrap}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}}.account-row{display:flex;flex-direction:column;gap:.35rem;margin-bottom:.9rem}.account-email{display:inline-flex;align-items:center;gap:.4rem;font-weight:700;color:var(--ink)}.streak-warn{display:flex;align-items:center;gap:.6rem;background:#fff4e8;border:2px solid #ffd9a8;color:var(--ink);border-radius:16px;padding:.8rem 1rem;font-weight:600;margin-bottom:1rem}.pw-form{display:flex;flex-direction:column;gap:.6rem;max-width:360px;margin-bottom:1rem}.pw-form label{font-weight:700;font-size:.9rem}.pw-form input{padding:.7rem .9rem;border:2px solid var(--line);border-radius:12px;font:inherit;background:var(--surface);color:var(--ink)}.pw-form input:focus{outline:none;border-color:var(--coral)}.account-actions{display:flex;flex-wrap:wrap;gap:.6rem;margin-bottom:1.2rem}.danger-zone{border-top:1px dashed var(--line);padding-top:1rem}.btn.danger{background:#fff0ec;color:var(--coral-deep);border:2px solid #ffc4b5}.btn.danger:hover{background:#ffe3da}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
