*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--green: #58CC02;--green-dark: #46A302;--blue: #1CB0F6;--red: #FF4B4B;--gold: #FFC800;--gold-dark: #E6B200;--purple: #CE82FF;--bg: #111827;--surface: #1f2937;--surface-hi: #2d3748;--border: #374151;--text: #f1f5f9;--text-light: #6b7280;--tint-green: #0d2a10;--tint-gold: #1e1a00;--tint-red: #2a0f0f;--tint-blue: #0a1e30;--radius: 16px;--sat: env(safe-area-inset-top, 0px);--sar: env(safe-area-inset-right, 0px);--sab: env(safe-area-inset-bottom, 0px);--sal: env(safe-area-inset-left, 0px)}html,body,#root{min-height:100%;font-family:Nunito,system-ui,sans-serif;background:var(--bg);color:var(--text);color-scheme:dark;-webkit-font-smoothing:antialiased;overscroll-behavior:none}.app{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;background:var(--bg)}button{font-family:inherit;cursor:pointer;border:none;outline:none;touch-action:manipulation;-webkit-tap-highlight-color:transparent}input{-webkit-tap-highlight-color:transparent}.fr-flag{display:flex;overflow:hidden;flex-shrink:0;box-shadow:0 1px 6px #00000059}.fr-flag span{flex:1;display:block}.fr-flag span:nth-child(1){background:#002395}.fr-flag span:nth-child(2){background:#ededed}.fr-flag span:nth-child(3){background:#ed2939}.fr-flag-xs{width:22px;height:15px;border-radius:3px}.fr-flag-sm{width:30px;height:20px;border-radius:4px}.fr-flag-md{width:44px;height:30px;border-radius:6px}.fr-flag-lg{width:64px;height:44px;border-radius:8px}.loading-screen{min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;background:var(--bg)}.loading-screen .fr-flag-lg{animation:pulse-flag 1.4s ease-in-out infinite}@keyframes pulse-flag{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.12);opacity:.7}}.loading-text{font-size:17px;font-weight:700;color:var(--text-light)}.map-header,.level-header{width:100%;display:flex;align-items:center;padding:calc(var(--sat) + 14px) calc(var(--sar) + 16px) 14px calc(var(--sal) + 16px);background:var(--surface);border-bottom:2px solid var(--border);position:sticky;top:0;z-index:10;gap:12px}.map-logo{display:flex;align-items:center;gap:10px;flex:1}.logo-name{font-size:22px}.monlingo-logo{font-weight:900;letter-spacing:-.5px}.logo-mon{color:#3b82f6}.logo-lin{color:#f1f5f9}.logo-go{color:#ef4444}.header-right{display:flex;align-items:center;gap:10px;flex-shrink:0}.xp-badge{display:flex;align-items:center;gap:6px;background:var(--tint-gold);border:2px solid var(--gold-dark);border-radius:99px;padding:6px 14px;font-size:14px;font-weight:800;color:var(--gold)}.user-pill{display:flex;align-items:center;gap:8px;background:var(--surface-hi);border:1px solid var(--border);border-radius:99px;padding:6px 6px 6px 12px}.user-name{font-size:13px;font-weight:700;color:var(--text-light);max-width:80px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.btn-logout{background:var(--surface);color:var(--text-light);font-size:15px;width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:1px solid var(--border);transition:background .15s,color .15s}.btn-logout:hover{background:var(--tint-red);color:var(--red);border-color:var(--red)}.streak-badge{display:flex;align-items:center;gap:4px;background:#2d1a00;border:2px solid #ff6b00;border-radius:99px;padding:6px 12px;font-size:14px;font-weight:800;color:#ff9500}.streak-num{font-size:15px}.btn-mute{background:var(--surface-hi);border:1px solid var(--border);border-radius:50%;width:36px;height:36px;font-size:18px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s}.btn-mute:active{background:var(--border)}.user-avatar-btn{background:var(--green);color:#fff;font-size:16px;font-weight:900;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 2px 0 var(--green-dark);transition:transform .1s}.user-avatar-btn:active{transform:scale(.92)}.map-banner{width:100%;display:flex;align-items:center;gap:16px;background:linear-gradient(135deg,#1a3a7a,#0d1f50);color:var(--text);padding:20px calc(var(--sar) + 20px) 20px calc(var(--sal) + 20px)}.banner-title{font-size:20px;font-weight:900}.banner-sub{font-size:13px;opacity:.75;font-weight:600;margin-top:3px}.levels-screen{display:flex;flex-direction:column;min-height:100dvh;background:var(--bg)}.levels-list{padding:16px calc(var(--sal) + 12px) calc(var(--sab) + 24px) calc(var(--sar) + 12px);display:flex;flex-direction:column;gap:10px}.level-card{display:flex;align-items:center;gap:16px;background:var(--surface);border:2px solid var(--border);border-radius:20px;padding:18px 16px;width:100%;text-align:left;min-height:84px;transition:transform .12s,border-color .15s;-webkit-tap-highlight-color:transparent}.level-card.level-open:active{transform:scale(.98)}.level-card.level-locked{opacity:.4;cursor:default}.level-card.level-done{border-color:var(--green-dark)}.level-icon-wrap{width:60px;height:60px;border-radius:18px;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:var(--surface-hi);border:2px solid var(--border)}.level-icon{font-size:28px;line-height:1}.level-body{flex:1;display:flex;flex-direction:column;gap:4px;min-width:0}.level-top-row{display:flex;justify-content:space-between;align-items:center;gap:8px}.level-name{font-size:18px;font-weight:900;color:var(--text)}.level-progress-text{font-size:13px;font-weight:800;color:var(--text-light);white-space:nowrap}.level-soon-badge{font-size:11px;font-weight:800;color:var(--text-light);background:var(--surface-hi);border:1px solid var(--border);border-radius:8px;padding:3px 10px}.level-sub{font-size:13px;color:var(--text-light);font-weight:600}.level-bar{height:7px;background:var(--surface-hi);border-radius:99px;overflow:hidden;margin-top:7px}.level-bar-fill{height:100%;border-radius:99px;transition:width .5s ease;min-width:0}.level-chevron{font-size:28px;color:var(--text-light);flex-shrink:0}.map-screen{display:flex;flex-direction:column;min-height:100dvh;background:var(--bg)}.level-header{gap:12px}.btn-back-level{background:none;color:var(--blue);font-size:15px;font-weight:800;padding:8px 12px;border-radius:10px;transition:background .15s;white-space:nowrap}.btn-back-level:active{background:var(--tint-blue)}.modules-list{padding:16px calc(var(--sal) + 12px) calc(var(--sab) + 24px) calc(var(--sar) + 12px);display:flex;flex-direction:column;gap:12px}.module-card{border-radius:20px;border:2px solid var(--border);background:var(--surface);overflow:hidden}.module-card.mod-done{border-color:var(--green-dark)}.module-card.mod-locked-full{opacity:.45;pointer-events:none;padding:16px}.module-card.mod-locked-full .mod-icon-locked{background:var(--surface-hi)!important;border-color:var(--border)!important}.mod-progress-bar{height:5px;background:var(--surface-hi)}.mod-progress-fill{height:100%;transition:width .5s ease;border-radius:0 3px 3px 0}.module-header{display:flex;align-items:center;gap:14px;padding:16px}.mod-icon-wrap{width:54px;height:54px;border-radius:15px;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:var(--surface-hi);border:2px solid var(--border)}.mod-icon{font-size:26px;line-height:1}.mod-meta{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.mod-number{font-size:11px;font-weight:800;color:var(--text-light);text-transform:uppercase;letter-spacing:.8px}.mod-title{font-size:17px;font-weight:900;color:var(--text)}.mod-desc{font-size:12px;color:var(--text-light);font-weight:600}.mod-badge{flex-shrink:0}.badge-done{background:var(--tint-green);border:2px solid var(--green);color:var(--green);display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;font-size:16px;font-weight:900}.badge-count{background:var(--surface-hi);border:2px solid var(--border);color:var(--text-light);display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;font-size:12px;font-weight:800}.module-items{border-top:2px solid var(--border);display:flex;flex-direction:column;gap:1px;background:var(--border)}.module-item{display:flex;align-items:center;gap:14px;padding:16px;background:var(--bg);min-height:68px;text-align:left;width:100%;transition:background .1s}.module-item:last-child{border-radius:0 0 18px 18px}.module-item.item-active:active,.module-item.item-done:active{background:var(--surface)}.module-item.item-locked{opacity:.5;cursor:default}.item-icon{font-size:24px;flex-shrink:0}.item-info{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.item-label{font-size:10px;font-weight:800;color:var(--text-light);text-transform:uppercase;letter-spacing:.7px}.item-title{font-size:15px;font-weight:700;color:var(--text)}.item-status{font-size:20px;font-weight:900;flex-shrink:0;color:var(--text-light)}.item-done .item-status{color:var(--green)}.item-active .item-status{color:var(--text)}.item-xp{font-size:12px;font-weight:800;color:var(--gold);background:var(--tint-gold);border:1px solid var(--gold-dark);border-radius:8px;padding:4px 9px;flex-shrink:0}.map-footer{display:flex;flex-direction:column;align-items:center;gap:8px;padding:24px;background:var(--surface);border-radius:var(--radius);border:2px dashed var(--border);text-align:center;font-size:14px;color:var(--text-light);font-weight:700}.map-footer span{font-size:32px}.profile-screen{display:flex;flex-direction:column;min-height:100dvh;background:var(--bg)}.profile-header-title{flex:1;text-align:center;font-size:17px;font-weight:900;color:var(--text)}.profile-body{flex:1;display:flex;flex-direction:column;align-items:center;gap:14px;padding:28px 20px calc(var(--sab) + 40px)}.profile-avatar{width:88px;height:88px;border-radius:50%;background:var(--green);color:#fff;font-size:40px;font-weight:900;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 0 var(--green-dark)}.profile-email{font-size:16px;font-weight:700;color:var(--text)}.profile-since{font-size:13px;color:var(--text-light);font-weight:600}.profile-stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;width:100%;max-width:380px;margin-top:8px}.profile-stat{background:var(--surface);border:2px solid var(--border);border-radius:18px;padding:18px 14px;display:flex;flex-direction:column;align-items:center;gap:6px;text-align:center}.profile-stat.flame{border-color:#ff6b00;background:#2d1a00}.profile-stat.gold{border-color:var(--gold-dark);background:var(--tint-gold)}.profile-stat.green{border-color:var(--green-dark);background:var(--tint-green)}.profile-stat.blue{border-color:var(--blue);background:var(--tint-blue)}.pstat-icon{font-size:28px}.pstat-num{font-size:26px;font-weight:900;color:var(--text)}.pstat-label{font-size:12px;font-weight:700;color:var(--text-light)}.profile-stat.flame .pstat-num{color:#ff9500}.profile-stat.gold .pstat-num{color:var(--gold)}.profile-stat.green .pstat-num{color:var(--green)}.profile-stat.blue .pstat-num{color:var(--blue)}.profile-overall{width:100%;max-width:380px;background:var(--surface);border:2px solid var(--border);border-radius:18px;padding:18px;display:flex;flex-direction:column;gap:8px}.overall-top{display:flex;justify-content:space-between;align-items:center}.overall-label{font-size:14px;font-weight:800;color:var(--text)}.overall-pct{font-size:16px;font-weight:900;color:var(--green)}.overall-bar{height:10px;background:var(--surface-hi);border-radius:99px;overflow:hidden}.overall-fill{height:100%;background:var(--green);border-radius:99px;transition:width .6s ease}.overall-sub{font-size:12px;color:var(--text-light);font-weight:600}.btn-logout-full{background:var(--tint-red);color:var(--red);border:2px solid var(--red);font-size:16px;font-weight:800;padding:16px;border-radius:var(--radius);width:100%;max-width:380px;margin-top:8px;min-height:54px;transition:background .15s}.btn-logout-full:active{background:#3a1010}.onboard-screen{min-height:100dvh;background:var(--bg);display:flex;flex-direction:column;padding:calc(var(--sat) + 16px) 24px calc(var(--sab) + 32px)}.onboard-skip{align-self:flex-end;background:none;color:var(--text-light);font-size:14px;font-weight:700;padding:8px 4px;margin-bottom:8px}.onboard-content{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:28px;text-align:center;animation:slide-in-right .3s ease}@keyframes slide-in-right{0%{transform:translate(28px);opacity:0}to{transform:translate(0);opacity:1}}.onboard-icon-wrap{width:148px;height:148px;border-radius:40px;display:flex;align-items:center;justify-content:center}.onboard-icon-row{display:flex;gap:6px;font-size:44px}.onboard-emoji{font-size:72px;line-height:1}.onboard-title{font-size:26px;font-weight:900;color:var(--text);line-height:1.2}.onboard-desc{font-size:16px;color:var(--text-light);font-weight:600;line-height:1.65;max-width:340px}.onboard-footer{display:flex;flex-direction:column;align-items:center;gap:20px;margin-top:16px}.onboard-dots{display:flex;gap:8px}.onboard-dot{width:8px;height:8px;border-radius:50%;background:var(--surface-hi);transition:all .3s ease}.onboard-dot.dot-active{width:28px;border-radius:4px}.onboard-dot.dot-done{background:var(--green)}.btn-onboard-next{background:var(--green);color:#fff;font-size:18px;font-weight:800;padding:18px;border-radius:var(--radius);min-height:58px;width:100%;max-width:360px;transition:transform .1s,box-shadow .1s}.btn-onboard-next:active{transform:translateY(3px)}.field-label-row{display:flex;justify-content:space-between;align-items:center}.forgot-link{background:none;color:var(--blue);font-size:12px;font-weight:700;padding:2px 0}.reset-success{background:var(--tint-green);border:1px solid var(--green-dark);border-radius:var(--radius);padding:20px 16px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:8px}.reset-icon{font-size:36px}.reset-success p{font-size:15px;font-weight:700;color:var(--green)}.reset-hint{font-size:13px!important;color:var(--text-light)!important;font-weight:600!important}.login-screen{min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:calc(var(--sat) + 24px) calc(var(--sar) + 20px) calc(var(--sab) + 24px) calc(var(--sal) + 20px);background:var(--bg)}.login-card{width:100%;max-width:420px;background:var(--surface);border:1px solid var(--border);border-radius:28px;padding:40px 28px 32px;display:flex;flex-direction:column;gap:20px;box-shadow:0 20px 60px #0006;animation:bounce-in .4s ease}.login-brand{text-align:center;display:flex;flex-direction:column;align-items:center;gap:10px}.login-title{font-size:30px;letter-spacing:-.5px;display:block}.login-sub{font-size:14px;color:var(--text-light);font-weight:600}.btn-google{display:flex;align-items:center;justify-content:center;gap:10px;background:var(--surface-hi);border:2px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:16px;font-weight:700;padding:16px;width:100%;min-height:56px;transition:background .15s}.btn-google:active{background:var(--bg)}.btn-google:disabled{opacity:.6}.login-divider{display:flex;align-items:center;gap:12px;color:var(--text-light);font-size:12px;font-weight:700}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:var(--border)}.login-form{display:flex;flex-direction:column;gap:16px}.field-group{display:flex;flex-direction:column;gap:7px}.field-label{font-size:12px;font-weight:800;color:var(--text-light);text-transform:uppercase;letter-spacing:.6px}.field-input{background:var(--bg);border:2px solid var(--border);border-radius:var(--radius);color:var(--text);font-family:inherit;font-size:16px;font-weight:600;padding:14px 16px;outline:none;min-height:54px;transition:border-color .15s}.field-input::placeholder{color:var(--text-light)}.field-input:focus{border-color:var(--green)}.login-error{font-size:14px;font-weight:700;color:var(--red);background:var(--tint-red);border:1px solid var(--red);border-radius:12px;padding:12px 16px}.btn-login{background:var(--green);color:#fff;font-size:17px;font-weight:800;padding:17px;border-radius:var(--radius);box-shadow:0 4px 0 var(--green-dark);min-height:56px;transition:transform .1s,box-shadow .1s,opacity .15s;margin-top:4px}.btn-login:active:not(:disabled){transform:translateY(3px);box-shadow:0 1px 0 var(--green-dark)}.btn-login:disabled{opacity:.6}.login-toggle{background:none;color:var(--text-light);font-size:15px;font-weight:700;text-align:center;padding:10px;border-radius:10px;transition:color .15s}.login-toggle:active{color:var(--green)}.player-screen{display:flex;flex-direction:column;min-height:100dvh;background:var(--bg)}.player-header{display:flex;align-items:center;gap:12px;padding:calc(var(--sat) + 14px) calc(var(--sar) + 16px) 14px calc(var(--sal) + 16px);border-bottom:2px solid var(--border);position:sticky;top:0;background:var(--bg);z-index:5}.btn-close{font-size:18px;font-weight:900;color:var(--text-light);background:none;padding:8px;border-radius:10px;min-width:40px;min-height:40px;display:flex;align-items:center;justify-content:center}.btn-close:active{background:var(--surface)}.progress-track{flex:1;height:14px;background:var(--surface-hi);border-radius:99px;overflow:hidden}.progress-fill{height:100%;border-radius:99px;transition:width .4s ease;min-width:4px}.hearts{display:flex;gap:4px;flex-shrink:0}.heart{font-size:22px}.heart.empty{opacity:.25;filter:grayscale(1)}.player-body{flex:1;padding:24px calc(var(--sar) + 16px) 140px calc(var(--sal) + 16px);display:flex;flex-direction:column;gap:24px;overflow-y:auto}.lesson-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 18px;border-radius:99px;font-size:13px;font-weight:800;width:fit-content;background:var(--tint-green);color:var(--green);border:1px solid var(--green-dark)}.eval-badge{background:var(--tint-gold)!important;color:var(--gold)!important;border:1px solid var(--gold-dark)!important}.exercise-top{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;flex-wrap:wrap}.q-counter-wrap{display:flex;flex-direction:column;align-items:flex-end;gap:2px}.q-subtitle{font-size:11px;font-weight:700;color:var(--text-light)}.q-counter{font-size:16px;font-weight:900;color:var(--text-light)}.btn-speak{background:var(--tint-blue);border:2px solid var(--blue);color:var(--blue);border-radius:50%;width:48px;height:48px;font-size:22px;display:flex;align-items:center;justify-content:center;flex-shrink:0;cursor:pointer;transition:background .15s,transform .1s;box-shadow:0 3px #06293f}.btn-speak:active{background:var(--blue);color:#fff;transform:scale(.92);box-shadow:none}.btn-speak.speaking{background:var(--blue);color:#fff;animation:pulse-speak .9s ease infinite}.btn-speak.speak-sm{width:32px;height:32px;font-size:15px;box-shadow:none;border-width:1px}@keyframes pulse-speak{0%,to{box-shadow:0 0 #1cb0f680}50%{box-shadow:0 0 0 7px #1cb0f600}}.mc-exercise{display:flex;flex-direction:column;gap:20px}.question-header{display:flex;align-items:flex-start;gap:14px}.question-header .exercise-question{flex:1}.exercise-question{font-size:20px;font-weight:800;color:var(--text);line-height:1.4}.options-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.options-grid.options-1col{grid-template-columns:1fr}.option-btn{padding:18px 14px;border-radius:var(--radius);border:2px solid var(--border);background:var(--surface);font-size:16px;font-weight:700;color:var(--text);box-shadow:0 4px #0d1117;min-height:68px;transition:transform .1s,box-shadow .1s;text-align:center}.option-btn:active:not(:disabled){transform:translateY(4px);box-shadow:0 0 #0d1117}.option-btn.correct{background:var(--tint-green);border-color:var(--green);color:var(--green);box-shadow:0 4px #0a1f0a}.option-btn.wrong-dim{background:var(--surface);border-color:var(--border);color:var(--text-light);box-shadow:none;opacity:.5}.match-exercise{display:flex;flex-direction:column;gap:20px}.match-columns{display:grid;grid-template-columns:1fr 1fr;gap:10px}.match-col{display:flex;flex-direction:column;gap:10px}.match-btn{padding:16px 10px;border-radius:var(--radius);border:2px solid var(--border);background:var(--surface);font-size:14px;font-weight:700;color:var(--text);box-shadow:0 3px #0d1117;min-height:56px;transition:all .12s;text-align:center}.match-btn:active:not(:disabled){transform:scale(.97)}.match-btn.active{background:var(--tint-blue);border-color:var(--blue);color:var(--blue);box-shadow:0 3px #061220}.match-btn.matched{background:var(--tint-green);border-color:var(--green);color:var(--green);opacity:.7;cursor:default;box-shadow:none}.match-btn.wrong{background:var(--tint-red);border-color:var(--red);color:var(--red);animation:shake .4s ease}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-7px)}40%{transform:translate(7px)}60%{transform:translate(-5px)}80%{transform:translate(5px)}}.feedback-bar{position:fixed;bottom:0;left:0;right:0;padding:16px 16px calc(var(--sab) + 20px);display:flex;justify-content:space-between;align-items:center;gap:14px;animation:slide-up .22s ease;z-index:20}@keyframes slide-up{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.fb-correct{background:var(--tint-green);border-top:3px solid var(--green)}.fb-wrong{background:var(--tint-red);border-top:3px solid var(--red)}.fb-text{display:flex;align-items:center;gap:8px;font-size:16px;font-weight:700;flex:1}.fb-correct .fb-text{color:var(--green)}.fb-wrong .fb-text{color:var(--red)}.fb-icon{font-size:20px;font-weight:900;flex-shrink:0}.btn-continue{background:var(--green);color:#fff;font-size:16px;font-weight:800;padding:16px 22px;border-radius:var(--radius);box-shadow:0 4px 0 var(--green-dark);white-space:nowrap;min-height:54px;transition:transform .1s,box-shadow .1s;flex-shrink:0}.btn-continue:active{transform:translateY(3px);box-shadow:0 1px 0 var(--green-dark)}.fb-wrong .btn-continue{background:var(--red);box-shadow:0 4px #b02020}.fb-wrong .btn-continue:active{box-shadow:0 1px #b02020}.failed-screen,.ex-done-screen{min-height:100dvh;background:var(--bg);display:flex;flex-direction:column;justify-content:center;align-items:center}.failed-card,.ex-done-card{text-align:center;padding:48px 28px;display:flex;flex-direction:column;align-items:center;gap:20px;width:100%;max-width:420px}.failed-icon,.ex-done-icon{font-size:80px;animation:bounce-in .4s ease}@keyframes bounce-in{0%{transform:scale(.5);opacity:0}70%{transform:scale(1.15)}to{transform:scale(1);opacity:1}}.failed-card h2{font-size:28px;font-weight:900;color:var(--red)}.failed-card p{font-size:16px;color:var(--text-light);font-weight:600}.ex-done-card h2{font-size:24px;font-weight:900;color:var(--text)}.ex-dots{display:flex;gap:10px}.ex-dot{width:16px;height:16px;border-radius:50%;background:var(--surface-hi);border:2px solid var(--border)}.ex-dot.dot-done{background:var(--green);border-color:var(--green-dark);box-shadow:0 0 8px var(--green)}.next-ex-info{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px 24px;text-align:center;display:flex;flex-direction:column;gap:4px;width:100%;max-width:320px}.next-label{font-size:11px;font-weight:800;color:var(--text-light);text-transform:uppercase;letter-spacing:.8px}.next-title{font-size:15px;font-weight:800;color:var(--text)}.btn-retry{background:var(--green);color:#fff;font-size:17px;font-weight:800;padding:18px 48px;border-radius:var(--radius);box-shadow:0 4px 0 var(--green-dark);min-height:58px;transition:transform .1s,box-shadow .1s;width:100%;max-width:320px}.btn-retry:active{transform:translateY(3px);box-shadow:0 1px 0 var(--green-dark)}.btn-exit-soft{background:none;color:var(--text-light);font-size:15px;font-weight:700;padding:12px 24px;border-radius:var(--radius);border:2px solid var(--border);min-height:50px;width:100%;max-width:320px}.btn-exit-soft:active{background:var(--surface)}.vocab-page{display:flex;flex-direction:column;min-height:100dvh;background:var(--bg)}.vocab-header-label{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:700;color:var(--text-light);flex:1;justify-content:center}.vocab-body{flex:1;padding:20px calc(var(--sar) + 14px) calc(var(--sab) + 48px) calc(var(--sal) + 14px);display:flex;flex-direction:column;gap:20px;overflow-y:auto}.vocab-intro{text-align:center}.vocab-title{font-size:22px;font-weight:900;color:var(--text);margin-bottom:6px}.vocab-subtitle{font-size:14px;color:var(--text-light);font-weight:600}.vocab-table{display:flex;flex-direction:column;gap:2px;background:var(--border);border-radius:var(--radius);overflow:hidden}.vocab-row{display:flex;align-items:flex-start;gap:10px;padding:14px;background:var(--surface);min-height:58px}.vocab-row:active{background:var(--surface-hi)}.vocab-left{display:flex;align-items:center;gap:10px;min-width:130px;flex-shrink:0}.vocab-num{font-size:11px;font-weight:800;color:var(--text-light);width:18px;text-align:right;flex-shrink:0}.vocab-fr{font-size:16px;font-weight:800;color:var(--text)}.vocab-arrow{color:var(--text-light);font-size:16px;flex-shrink:0;padding-top:2px}.vocab-right{display:flex;flex-direction:column;gap:3px;flex:1}.vocab-pt{font-size:15px;font-weight:700;color:var(--text)}.vocab-note{font-size:12px;color:var(--text-light);font-weight:600;font-style:italic}.vocab-cta{display:flex;flex-direction:column;align-items:center;gap:12px;margin-top:8px}.vocab-cta-info{font-size:13px;font-weight:700;color:var(--text-light);background:var(--surface);padding:8px 20px;border-radius:99px;border:1px solid var(--border)}.btn-proceed{background:var(--green);color:#fff;font-size:17px;font-weight:800;padding:18px;border-radius:var(--radius);box-shadow:0 4px 0 var(--green-dark);min-height:58px;transition:transform .1s,box-shadow .1s;width:100%}.btn-proceed:active{transform:translateY(3px);box-shadow:0 1px 0 var(--green-dark)}.completion-screen{min-height:100dvh;display:flex;align-items:center;justify-content:center;background:linear-gradient(160deg,#0d2010,#0a1929);padding:calc(var(--sat) + 24px) calc(var(--sar) + 20px) calc(var(--sab) + 24px) calc(var(--sal) + 20px)}.completion-card{background:var(--surface);border-radius:28px;padding:48px 28px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:18px;box-shadow:0 8px 40px #00000080;border:1px solid var(--border);width:100%;max-width:420px;animation:bounce-in .5s ease}.completion-icon{font-size:80px}.completion-title{font-size:28px;font-weight:900;color:var(--green)}.completion-subtitle{font-size:16px;color:var(--text-light);font-weight:700}.completion-mod-tag{display:inline-flex;align-items:center;gap:8px;padding:7px 18px;border-radius:99px;font-size:13px;font-weight:800;border:1px solid}.xp-gained{display:flex;align-items:center;gap:10px;background:var(--tint-gold);border:2px solid var(--gold-dark);border-radius:99px;padding:12px 32px}.xp-star{font-size:26px}.xp-amount{font-size:26px;font-weight:900;color:var(--gold)}.completion-stats{display:flex;gap:14px;width:100%}.stat-box{flex:1;background:var(--bg);border-radius:var(--radius);border:1px solid var(--border);padding:14px;display:flex;flex-direction:column;gap:4px}.stat-label{font-size:11px;color:var(--text-light);font-weight:700;text-transform:uppercase;letter-spacing:.5px}.stat-value{font-size:20px;font-weight:900;color:var(--text)}.btn-complete{background:var(--green);color:#fff;font-size:18px;font-weight:800;padding:18px;border-radius:var(--radius);box-shadow:0 4px 0 var(--green-dark);min-height:58px;transition:transform .1s,box-shadow .1s;width:100%;margin-top:4px}.btn-complete:active{transform:translateY(3px);box-shadow:0 1px 0 var(--green-dark)}.achievement-toast{position:fixed;bottom:calc(var(--sab) + 16px);left:50%;transform:translate(-50%);width:calc(100% - 32px);max-width:420px;background:var(--surface);border:2px solid var(--gold-dark);border-radius:20px;padding:16px;display:flex;align-items:center;gap:14px;z-index:100;box-shadow:0 8px 32px #00000080}.achievement-toast.toast-in{animation:toast-up .35s cubic-bezier(.34,1.56,.64,1) forwards}.achievement-toast.toast-out{animation:toast-down .3s ease forwards}@keyframes toast-up{0%{transform:translate(-50%) translateY(120%);opacity:0}to{transform:translate(-50%) translateY(0);opacity:1}}@keyframes toast-down{0%{transform:translate(-50%) translateY(0);opacity:1}to{transform:translate(-50%) translateY(120%);opacity:0}}.toast-icon-wrap{width:52px;height:52px;border-radius:14px;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:var(--tint-gold);border:2px solid var(--gold-dark)}.toast-icon{font-size:26px}.toast-body{display:flex;flex-direction:column;gap:2px}.toast-label{font-size:11px;font-weight:800;color:var(--gold);text-transform:uppercase;letter-spacing:.6px}.toast-title{font-size:17px;font-weight:900;color:var(--text)}.toast-desc{font-size:12px;font-weight:600;color:var(--text-light)}.achievements-section{width:100%;max-width:380px;display:flex;flex-direction:column;gap:14px}.achievements-title{font-size:17px;font-weight:900;color:var(--text);display:flex;align-items:center;justify-content:space-between}.achievements-count{font-size:13px;font-weight:800;color:var(--text-light);background:var(--surface);border:1px solid var(--border);border-radius:99px;padding:3px 12px}.achievements-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}.achievement-item{background:var(--surface);border:2px solid var(--border);border-radius:16px;padding:14px 10px;display:flex;flex-direction:column;align-items:center;gap:6px;text-align:center;transition:transform .15s}.achievement-item.ach-done{border-color:var(--border)}.achievement-item.ach-locked{opacity:.4}.ach-icon-wrap{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;background:var(--surface-hi);border:2px solid var(--border)}.ach-icon{font-size:24px}.ach-title{font-size:11px;font-weight:800;color:var(--text);line-height:1.2}.ach-desc{font-size:10px;color:var(--text-light);font-weight:600;line-height:1.2}.listening-exercise{display:flex;flex-direction:column;gap:20px}.listen-center{display:flex;flex-direction:column;align-items:center;gap:14px;padding:12px 0}.btn-listen{width:100px;height:100px;border-radius:50%;font-size:44px;background:var(--tint-blue);border:3px solid var(--blue);color:var(--blue);display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 6px #06293f;transition:all .15s;touch-action:manipulation}.btn-listen.unplayed{animation:pulse-listen 1.6s ease infinite}.btn-listen.speaking{background:var(--blue);color:#fff;animation:pulse-speak .9s ease infinite}.btn-listen:active{transform:scale(.9);box-shadow:none}@keyframes pulse-listen{0%,to{box-shadow:0 6px #06293f,0 0 #1cb0f673}50%{box-shadow:0 6px #06293f,0 0 0 14px #1cb0f600}}.listen-hint{font-size:13px;color:var(--text-light);font-weight:600}.listen-revealed{font-size:22px;font-weight:900;color:var(--text);background:var(--surface);border:2px solid var(--border);border-radius:14px;padding:10px 24px;animation:bounce-in .3s ease}.opt-locked{opacity:.45;cursor:not-allowed!important}.review-card{display:flex;align-items:center;gap:16px;background:var(--tint-blue);border:2px solid var(--blue);border-radius:20px;padding:18px 16px;width:100%;text-align:left;min-height:84px;cursor:pointer;transition:transform .12s;-webkit-tap-highlight-color:transparent}.review-card:active{transform:scale(.98)}.review-icon-wrap{width:60px;height:60px;border-radius:18px;background:#1cb0f633;border:2px solid rgba(28,176,246,.4);display:flex;align-items:center;justify-content:center;font-size:28px;flex-shrink:0}.review-count{background:var(--blue);color:#fff;font-size:13px;font-weight:900;padding:3px 10px;border-radius:99px}.lb-screen{display:flex;flex-direction:column;min-height:100dvh;background:var(--bg)}.lb-body{flex:1;padding:20px 16px calc(var(--sab) + 32px);display:flex;flex-direction:column;gap:16px;max-width:520px;width:100%;align-self:center}.lb-week-banner{display:flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:12px 16px}.lb-week-icon{font-size:20px}.lb-week-text{font-size:14px;font-weight:700;color:var(--text-light)}.lb-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;text-align:center;padding:40px 20px;color:var(--text-light);font-size:14px;font-weight:600}.lb-state span{font-size:48px}.lb-spinner{animation:pulse-flag 1.2s ease infinite}.lb-list{display:flex;flex-direction:column;gap:8px}.lb-row{display:flex;align-items:center;gap:14px;background:var(--surface);border:2px solid var(--border);border-radius:14px;padding:14px 16px;min-height:60px}.lb-row.lb-me{border-color:var(--blue);background:var(--tint-blue)}.lb-row.lb-outside{opacity:.85}.lb-rank{font-size:22px;font-weight:900;width:36px;text-align:center;flex-shrink:0}.lb-rank:not(.lb-medal){font-size:15px;color:var(--text-light)}.lb-name{flex:1;font-size:16px;font-weight:800;color:var(--text);display:flex;align-items:center;gap:8px;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lb-you-tag{font-size:11px;font-weight:800;color:var(--blue);background:#1cb0f626;border:1px solid rgba(28,176,246,.3);border-radius:6px;padding:2px 7px;flex-shrink:0}.lb-xp{font-size:15px;font-weight:900;color:var(--gold);flex-shrink:0}.lb-separator{text-align:center;color:var(--text-light);font-size:12px;font-weight:700;letter-spacing:2px}.lb-reset-info{text-align:center;font-size:12px;color:var(--text-light);font-weight:600}.btn-leaderboard{background:var(--surface-hi);border:1px solid var(--border);border-radius:50%;width:36px;height:36px;font-size:18px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s}.btn-leaderboard:active{background:var(--tint-gold)}.btn-toast-share{background:var(--surface-hi);border:1px solid var(--border);border-radius:50%;width:38px;height:38px;font-size:17px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s}.btn-toast-share:active{background:var(--border)}.toast-copied{color:var(--green);font-size:18px;font-weight:900}.btn-share-completion{background:none;color:var(--text-light);font-size:14px;font-weight:700;padding:12px;border-radius:var(--radius);border:2px solid var(--border);width:100%;transition:background .15s,color .15s;min-height:48px}.btn-share-completion:active{background:var(--surface);color:var(--text)}@media (min-width: 600px){.levels-list,.modules-list{max-width:540px;margin:0 auto;width:100%}.map-banner{max-width:100%}.level-card.level-open:hover{transform:translateY(-2px);border-color:var(--blue);box-shadow:0 6px 20px #00000040}.option-btn:hover:not(:disabled){background:var(--surface-hi);border-color:var(--blue)}.btn-proceed:hover{transform:translateY(-2px);box-shadow:0 6px 0 var(--green-dark)}.btn-login:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 0 var(--green-dark)}.btn-continue:hover,.btn-retry:hover{transform:translateY(-2px);box-shadow:0 6px 0 var(--green-dark)}}@media (min-width: 600px){.player-screen,.vocab-page{max-width:640px;margin:0 auto;width:100%}.feedback-bar{max-width:640px;left:50%;right:auto;transform:translate(-50%)}@keyframes slide-up{0%{transform:translate(-50%) translateY(100%);opacity:0}to{transform:translate(-50%) translateY(0);opacity:1}}}
