*,*: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: #0e1520;--surface: #1c2537;--surface-hi: #28354e;--border: #2e4060;--text: #f1f5f9;--text-light: #7a8fa6;--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-premium-badge{font-size:11px;font-weight:800;color:#a855f7;background:#a855f722;border:1px solid #a855f755;border-radius:8px;padding:3px 10px}.level-card.level-premium-locked{border-color:#a855f744;cursor:pointer;opacity:.85}.level-card.level-premium-locked:hover{opacity:1;border-color:#a855f7}.level-icon-premium{background:#a855f722!important;border:2px solid #a855f755!important}.landing-free-note{font-size:13px;color:var(--text-light);margin:0}.skeleton-screen{display:flex;flex-direction:column;min-height:100dvh;background:var(--bg)}.skeleton-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--surface);border-bottom:1px solid var(--border)}.sk-header-right{display:flex;gap:8px;align-items:center}.skeleton-body{padding:20px 16px;display:flex;flex-direction:column;gap:16px}.sk{border-radius:12px;background:linear-gradient(90deg,var(--surface-hi) 25%,var(--surface) 50%,var(--surface-hi) 75%);background-size:200% 100%;animation:sk-shimmer 1.6s ease-in-out infinite}@keyframes sk-shimmer{0%{background-position:200% center}to{background-position:-200% center}}.sk-logo{width:120px;height:32px}.sk-badge{width:60px;height:32px;border-radius:20px}.sk-avatar{width:36px;height:36px;border-radius:50%}.sk-banner{height:80px;border-radius:16px}.sk-card{height:72px;border-radius:20px}.daily-mission-card{display:flex;align-items:center;gap:14px;background:linear-gradient(135deg,#ce82ff22,#ce82ff11);border:2px solid #CE82FF55;border-radius:20px;padding:16px;cursor:pointer;text-align:left;width:100%;transition:border-color .15s}.daily-mission-card:hover:not(:disabled){border-color:#ce82ff}.daily-mission-card.daily-done{opacity:.6;cursor:default}.daily-mission-card.daily-locked{opacity:.5;cursor:default;background:var(--surface);border-color:var(--border)}.daily-icon-wrap{width:48px;height:48px;background:#ce82ff22;border:2px solid #CE82FF55;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0}.daily-xp{font-size:12px;font-weight:800;color:#ce82ff;background:#ce82ff22;border:1px solid #CE82FF44;border-radius:8px;padding:3px 10px;white-space:nowrap}.hearts-badge{display:flex;align-items:center;gap:4px;background:#ff4b4b20;border:1.5px solid #FF4B4B44;border-radius:20px;padding:4px 10px}.hearts-badge.hearts-premium{background:#a855f722;border-color:#a855f755}.category-screen{display:flex;flex-direction:column;min-height:100dvh}.category-hero{display:flex;align-items:center;gap:16px;padding:20px 20px 8px}.category-list{display:flex;flex-direction:column;gap:12px;padding:8px 16px calc(80px + var(--sab))}.category-card{display:flex;align-items:center;gap:14px;background:var(--surface);border:2px solid var(--border);border-radius:20px;padding:18px 16px;cursor:pointer;text-align:left;width:100%;transition:border-color .15s,transform .1s}.category-card:hover{border-color:var(--border);transform:translateY(-1px)}.category-card:active{transform:translateY(1px)}.category-card.cat-done{border-color:var(--green-dark)}.cat-icon-wrap{width:52px;height:52px;border-radius:16px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.cat-icon{font-size:26px}.cat-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:5px}.cat-top-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.cat-name{font-size:19px;font-weight:900;color:var(--text)}.cat-progress{font-size:13px;font-weight:800;color:var(--text-light);white-space:nowrap}.cat-subtitle{font-size:13px;color:var(--text-light);margin:0}.cat-bar{height:6px;background:var(--surface-hi);border-radius:3px;overflow:hidden}.cat-bar-fill{height:100%;border-radius:3px;transition:width .5s ease}.cat-chevron{font-size:22px;color:var(--text-light);flex-shrink:0}.category-card.cat-locked{opacity:.45;cursor:default;pointer-events:none}.cat-icon-locked{background:var(--surface-hi)!important;border-color:var(--border)!important}.leaderboard-card{display:flex;align-items:center;gap:14px;background:linear-gradient(135deg,#ffc80022,#ffc80011);border:2px solid #FFC80055;border-radius:20px;padding:16px;cursor:pointer;text-align:left;width:100%;transition:border-color .15s}.leaderboard-card:hover{border-color:#ffc800}.lb-card-icon-wrap{width:48px;height:48px;background:#ffc80022;border:2px solid #FFC80055;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0}.lb-card-badge{font-size:11px;font-weight:800;color:#ffc800;background:#ffc80022;border:1px solid #FFC80044;border-radius:8px;padding:3px 10px;white-space:nowrap}.streak-risk-banner{background:#ff960022;border-bottom:1px solid #FF960044;color:#ff9600;font-size:14px;font-weight:700;padding:12px 20px;text-align:center}.placement-screen{display:flex;flex-direction:column;min-height:100dvh;background:var(--bg)}.placement-result{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;padding:32px 24px;text-align:center}.placement-result-icon{font-size:64px}.placement-result-title{font-size:28px;font-weight:900;color:var(--text);margin:0}.placement-result-level{font-size:16px;color:var(--text-light);margin:0}.placement-result-level strong{color:var(--text)}.placement-result-sub{font-size:14px;color:var(--text-light);margin:0}.btn-placement-confirm{background:#ce82ff;color:#fff;border:none;border-radius:14px;font-size:17px;font-weight:800;padding:16px 32px;cursor:pointer;box-shadow:0 4px #9c50d0;width:100%;max-width:320px;margin-top:8px}.btn-placement-zero{background:transparent;border:none;color:var(--text-light);font-size:14px;font-weight:600;cursor:pointer;padding:8px}.levelup-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:1000;padding:24px}.levelup-card{background:var(--surface);border-radius:24px;padding:32px 24px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:12px;max-width:340px;width:100%;border:2px solid var(--border);animation:levelup-pop .4s cubic-bezier(.34,1.56,.64,1)}@keyframes levelup-pop{0%{transform:scale(.7);opacity:0}to{transform:scale(1);opacity:1}}.levelup-icon{width:80px;height:80px;border-radius:24px;display:flex;align-items:center;justify-content:center;font-size:40px}.levelup-label{font-size:11px;font-weight:900;letter-spacing:2px;color:var(--text-light);text-transform:uppercase;margin:0}.levelup-title{font-size:26px;font-weight:900;color:var(--text);margin:0}.levelup-sub{font-size:14px;color:var(--text-light);margin:0}.btn-levelup-continue{color:#fff;border:none;border-radius:14px;font-size:17px;font-weight:800;padding:16px 32px;cursor:pointer;width:100%;margin-top:8px;transition:transform .1s}.btn-levelup-continue:active{transform:translateY(2px)}.onboard-last-actions{display:flex;flex-direction:column;gap:10px;width:100%}.btn-onboard-placement{background:transparent;border:2px solid var(--border);border-radius:14px;color:var(--text-light);font-size:15px;font-weight:700;padding:14px;cursor:pointer;width:100%}.redeem-screen{display:flex;flex-direction:column;min-height:100dvh}.redeem-body{flex:1;padding:24px 20px 40px;display:flex;flex-direction:column;gap:28px;max-width:480px;margin:0 auto;width:100%}.redeem-hero{text-align:center;display:flex;flex-direction:column;gap:10px;align-items:center}.redeem-icon{font-size:52px}.redeem-title{font-size:22px;font-weight:900;color:var(--text);margin:0}.redeem-sub{font-size:14px;color:var(--text-light);margin:0;line-height:1.5}.redeem-form{display:flex;flex-direction:column;gap:12px}.redeem-input{background:var(--surface-hi);border:2px solid var(--border);border-radius:14px;color:var(--text);font-size:20px;font-weight:800;letter-spacing:2px;padding:16px;text-align:center;text-transform:uppercase;outline:none;width:100%;box-sizing:border-box}.redeem-input:focus{border-color:#a855f7}.redeem-error{color:#ff4b4b;font-size:13px;font-weight:700;text-align:center;margin:0}.btn-redeem{background:#a855f7;color:#fff;border:none;border-radius:14px;font-size:16px;font-weight:800;padding:16px;cursor:pointer;box-shadow:0 4px #7c3aed;transition:transform .1s,box-shadow .1s}.btn-redeem:active{transform:translateY(2px);box-shadow:0 2px #7c3aed}.btn-redeem:disabled{opacity:.5;cursor:not-allowed;transform:none}.redeem-features{background:var(--surface-hi);border-radius:16px;padding:18px 20px;border:1px solid var(--border)}.redeem-features-title{font-size:13px;font-weight:800;color:var(--text-light);margin:0 0 10px;text-transform:uppercase;letter-spacing:.5px}.redeem-features-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.redeem-features-list li{font-size:15px;font-weight:700;color:var(--text)}.typing-ex{display:flex;flex-direction:column;gap:16px;padding:8px 0}.typing-header-row{display:flex;align-items:center;justify-content:center;gap:10px}.typing-prompt{font-size:14px;font-weight:700;color:var(--text-light);margin:0;text-align:center}.typing-pt{font-size:22px;font-weight:900;color:var(--text);text-align:center;padding:12px 16px;background:var(--surface-hi);border-radius:14px}.typing-input-wrap{display:flex;align-items:center;gap:8px}.typing-input{flex:1;background:var(--surface-hi);border:2px solid var(--border);border-radius:14px;color:var(--text);font-size:18px;font-weight:700;padding:14px 16px;outline:none;width:100%;box-sizing:border-box;font-family:inherit}.typing-input:focus{border-color:#ce82ff}.typing-input-wrap.typing-ok .typing-input{border-color:var(--green);background:#58cc0211}.typing-input-wrap.typing-err .typing-input{border-color:#ff4b4b;background:#ff4b4b11}.typing-correct-answer{font-size:14px;color:var(--text-light);margin:0;text-align:center}.typing-correct-answer strong{color:var(--text)}.typing-almost-note{display:flex;flex-direction:column;align-items:center;gap:2px;background:#ffc80022;border:1.5px solid #FFC80066;border-radius:12px;padding:10px 16px;font-size:14px}.typing-almost-note span:first-child{font-weight:800;color:var(--gold)}.typing-almost-note strong{color:var(--text)}.typing-wrong-note{text-align:center}.typing-encourage{font-size:14px;color:var(--text-light);margin:0;font-style:italic}.btn-typing-check{background:#ce82ff;color:#fff;border:none;border-radius:14px;font-size:16px;font-weight:800;padding:14px;cursor:pointer;box-shadow:0 4px #9c50d0;transition:transform .1s}.btn-typing-check:disabled{opacity:.4;cursor:not-allowed;box-shadow:none}.btn-typing-check:not(:disabled):active{transform:translateY(2px);box-shadow:0 2px #9c50d0}.vocab-sentence{font-size:12px;font-style:italic;color:#1cb0f6;display:block;margin-top:2px}.dict-screen{display:flex;flex-direction:column;min-height:100dvh}.dict-body{flex:1;display:flex;flex-direction:column;gap:14px;padding:16px 16px 32px}.dict-stats{text-align:center}.dict-count{font-size:14px;color:var(--text-light)}.dict-count strong{color:var(--text);font-size:18px}.dict-search-wrap{position:relative}.dict-search{width:100%;box-sizing:border-box;background:var(--surface-hi);border:2px solid var(--border);border-radius:14px;color:var(--text);font-size:15px;padding:12px 40px 12px 16px;outline:none}.dict-search:focus{border-color:#1cb0f6}.dict-search-clear{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-light);font-size:16px;cursor:pointer}.dict-empty{text-align:center;padding:40px 20px;color:var(--text-light);display:flex;flex-direction:column;gap:8px;align-items:center;font-size:15px}.dict-empty span{font-size:36px}.dict-list{display:flex;flex-direction:column;gap:10px}.dict-row{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:14px 16px;display:flex;flex-direction:column;gap:6px}.dict-row-main{display:flex;align-items:center;justify-content:space-between;gap:8px}.dict-fr-wrap{display:flex;align-items:center;gap:8px}.dict-fr{font-size:17px;font-weight:900;color:var(--text)}.dict-pt{font-size:14px;color:var(--text-light);font-weight:600;text-align:right;flex:1}.dict-sentence{font-size:12px;font-style:italic;color:#1cb0f6;margin:0}.dict-note{font-size:12px;color:var(--text-light);margin:0}.dict-mod-tag{font-size:11px;font-weight:700;border-radius:8px;padding:3px 10px;border:1px solid;align-self:flex-start}.dictionary-card{display:flex;align-items:center;gap:14px;background:linear-gradient(135deg,#1cb0f622,#1cb0f611);border:2px solid #1CB0F655;border-radius:20px;padding:16px;cursor:pointer;text-align:left;width:100%;transition:border-color .15s}.dictionary-card:hover{border-color:#1cb0f6}.dict-card-badge{font-size:11px;font-weight:800;color:#1cb0f6;background:#1cb0f622;border:1px solid #1CB0F644;border-radius:8px;padding:3px 10px;white-space:nowrap}.admin-screen{display:flex;flex-direction:column;min-height:100dvh}.admin-body{flex:1;padding:20px;display:flex;flex-direction:column;gap:20px;max-width:600px;margin:0 auto;width:100%;box-sizing:border-box}.admin-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.admin-stat{background:var(--surface-hi);border-radius:14px;padding:14px;text-align:center;display:flex;flex-direction:column;gap:4px;border:1px solid var(--border)}.admin-stat.green .admin-stat-num{color:var(--green)}.admin-stat.red .admin-stat-num{color:#ff4b4b}.admin-stat-num{font-size:24px;font-weight:900;color:var(--text)}.admin-stat-label{font-size:11px;font-weight:700;color:var(--text-light);text-transform:uppercase}.btn-generate{background:var(--green);color:#fff;border:none;border-radius:14px;font-size:16px;font-weight:800;padding:16px;cursor:pointer;box-shadow:0 4px 0 var(--green-dark)}.btn-generate:disabled{opacity:.5;cursor:not-allowed}.admin-loading{text-align:center;color:var(--text-light)}.admin-codes-list{display:flex;flex-direction:column;gap:10px}.admin-code-row{display:flex;align-items:center;justify-content:space-between;background:var(--surface-hi);border-radius:12px;padding:14px 16px;border:1px solid var(--border)}.admin-code-row.code-used{opacity:.5}.code-info{display:flex;flex-direction:column;gap:4px}.code-value{font-size:17px;font-weight:900;color:var(--text);letter-spacing:1px;font-family:monospace}.code-status{font-size:12px;font-weight:600;color:var(--text-light)}.btn-copy{background:var(--surface);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:13px;font-weight:700;padding:6px 14px;cursor:pointer;white-space:nowrap}.premium-active-badge{background:#a855f722;border:1px solid #a855f755;border-radius:14px;color:#a855f7;font-size:15px;font-weight:800;padding:14px;text-align:center}.btn-redeem-profile{background:#a855f7;color:#fff;border:none;border-radius:14px;font-size:15px;font-weight:800;padding:14px;cursor:pointer;box-shadow:0 4px #7c3aed;width:100%}.btn-admin{background:var(--surface-hi);border:1px solid var(--border);border-radius:14px;color:var(--text-light);font-size:14px;font-weight:700;padding:12px;cursor:pointer;width:100%}.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}.module-toggle{width:100%;background:none;border:none;cursor:pointer;padding:0;text-align:left}.mod-chevron{font-size:22px;color:var(--text-light);flex-shrink:0;margin-left:4px;transition:transform .25s ease;display:inline-block}.mod-chevron.chevron-open{transform:rotate(90deg)}.module-items-wrap{display:grid;grid-template-rows:0fr;transition:grid-template-rows .3s ease}.module-items-wrap.items-open{grid-template-rows:1fr}.module-items{border-top:1px solid var(--border);overflow:hidden}.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(80px + var(--sab))}.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;animation:opt-pop .35s ease}.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}.fb-retry-hint{font-size:12px;font-weight:600;opacity:.7;white-space:nowrap}.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}.failed-upsell{gap:14px;padding:36px 24px}.upsell-title{font-size:26px;font-weight:900;color:var(--red);margin:0}.upsell-sub{font-size:15px;color:var(--text-light);font-weight:600;margin:0;line-height:1.4}.upsell-perks{list-style:none;margin:4px 0;padding:14px 18px;background:var(--surface-hi);border-radius:14px;border:1px solid var(--border);width:100%;display:flex;flex-direction:column;gap:9px;text-align:left}.upsell-perks li{font-size:15px;font-weight:700;color:var(--text)}.btn-upsell-buy{width:100%;padding:16px;border-radius:14px;border:none;background:#a855f7;color:#fff;font-size:1.05rem;font-weight:900;cursor:pointer;box-shadow:0 4px #7e22ce;transition:transform .1s,box-shadow .1s}.btn-upsell-buy:active{transform:translateY(2px);box-shadow:0 2px #7e22ce}.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-already-done{background:var(--surface-hi);border-color:var(--border);padding:12px 20px}.xp-zero{font-size:15px!important;color:var(--text-light)!important;font-weight:700}.xp-star{font-size:26px}.xp-amount{font-size:26px;font-weight:900;color:var(--gold)}.completion-stats{display:grid;grid-template-columns:1fr 1fr;gap:10px;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(80px + var(--sab));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}}}.btn-buy-premium{display:block;width:100%;padding:16px;border-radius:12px;border:none;background:#009ee3;color:#fff;font-size:1.05rem;font-weight:800;cursor:pointer;margin-top:4px;transition:transform .1s,box-shadow .1s;box-shadow:0 4px #007ab5}.btn-buy-premium:active:not(:disabled){transform:translateY(2px);box-shadow:0 2px #007ab5}.btn-buy-premium:disabled{opacity:.6;cursor:not-allowed}.redeem-safe-note{text-align:center;font-size:.78rem;color:var(--text-light);margin-top:8px}.flashcard-screen{display:flex;flex-direction:column;min-height:100dvh}.fc-counter{font-size:13px;font-weight:700;color:var(--text-light);margin-left:auto}.flashcard-body{flex:1;display:flex;flex-direction:column;align-items:center;gap:20px;padding:20px 20px 32px;max-width:480px;margin:0 auto;width:100%}.fc-hint{font-size:13px;color:var(--text-light);margin:0;text-align:center;font-style:italic}.fc-wrap{width:100%;perspective:1200px;cursor:pointer}.fc-card{width:100%;min-height:220px;position:relative;transform-style:preserve-3d;transition:transform .45s cubic-bezier(.4,0,.2,1)}.fc-card.fc-flipped{transform:rotateY(180deg)}.fc-face{position:absolute;top:0;right:0;bottom:0;left:0;backface-visibility:hidden;-webkit-backface-visibility:hidden;border-radius:20px;border:2px solid var(--border);background:var(--surface);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:28px 24px;box-shadow:0 4px 20px #0003}.fc-back{transform:rotateY(180deg)}.fc-mod-tag{font-size:12px;font-weight:700;opacity:.8}.fc-word{font-size:30px;font-weight:900;color:var(--text);text-align:center;margin:0;line-height:1.2}.fc-pt{color:var(--blue)}.fc-note{font-size:13px;color:var(--text-light);text-align:center;margin:0;font-style:italic}.fc-controls{display:flex;gap:10px;width:100%;align-items:center}.fc-btn{flex:1;padding:12px;border-radius:12px;border:2px solid var(--border);background:var(--surface-hi);color:var(--text);font-size:14px;font-weight:700;cursor:pointer;font-family:inherit;transition:opacity .15s}.fc-btn:disabled{opacity:.3;cursor:default}.fc-shuffle{flex:0 0 48px;font-size:18px}.fc-progress{width:100%;height:4px;background:var(--surface-hi);border-radius:4px;overflow:hidden}.fc-progress-fill{height:100%;background:var(--blue);border-radius:4px;transition:width .3s}.flashcard-empty{flex:1;display:flex;align-items:center;justify-content:center;padding:40px 24px;text-align:center;color:var(--text-light)}.grammar-note{display:flex;gap:10px;align-items:flex-start;background:#1cb0f611;border:1.5px solid #1CB0F633;border-radius:14px;padding:14px 16px}.grammar-note-icon{font-size:18px;flex-shrink:0;margin-top:1px}.grammar-note-text{font-size:14px;color:var(--text-light);line-height:1.55;margin:0}.conjugation-section{display:flex;flex-direction:column;gap:8px}.conjugation-title{font-size:13px;font-weight:800;color:var(--text-light);text-transform:uppercase;letter-spacing:.5px;margin:0 0 4px}.conj-table{background:var(--surface-hi);border-radius:12px;overflow:hidden;border:1px solid var(--border)}.conj-toggle{width:100%;display:flex;justify-content:space-between;align-items:center;padding:12px 14px;background:none;border:none;color:var(--text);font-size:14px;font-weight:700;cursor:pointer;text-align:left;gap:8px}.conj-toggle:active{background:var(--surface)}.conj-arrow{color:var(--text-light);font-size:11px;flex-shrink:0}.conj-rows{border-top:1px solid var(--border)}.conj-row{display:flex;justify-content:space-between;align-items:center;padding:9px 14px;border-bottom:1px solid var(--border)}.conj-row:last-child{border-bottom:none}.conj-pr{font-size:13px;color:var(--text-light);font-weight:600}.conj-form{font-size:15px;color:var(--text);font-weight:800}.ordering-ex{display:flex;flex-direction:column;gap:16px;padding:0 4px}.ordering-prompt{font-size:14px;color:var(--text-light);font-weight:700;text-align:center;margin:0;text-transform:uppercase;letter-spacing:.4px}.ordering-pt{font-size:20px;font-weight:900;color:var(--text);text-align:center;margin:0;line-height:1.3}.ord-answer{min-height:56px;border-radius:14px;border:2px dashed var(--border);padding:10px 12px;display:flex;flex-wrap:wrap;gap:8px;align-items:center;transition:border-color .2s}.ord-answer-ok{border-color:var(--green);background:#58cc0211;border-style:solid}.ord-answer-err{border-color:var(--red);background:#ff4b4b11;border-style:solid}.ord-answer-idle:has(.chip-placed){border-style:solid;border-color:var(--border)}.ord-placeholder{font-size:14px;color:var(--text-light);font-style:italic;margin:auto}.ord-correct-hint{font-size:13px;color:var(--text-light);text-align:center;margin:-4px 0 0}.ord-correct-hint strong{color:var(--text)}.ord-speak-row{display:flex;align-items:center;gap:8px;justify-content:center}.ord-speak-label{font-size:15px;color:var(--text);font-style:italic}.ord-bank{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;min-height:44px;padding:4px 0}.word-chip{padding:8px 14px;border-radius:10px;font-size:15px;font-weight:700;cursor:pointer;transition:transform .1s,box-shadow .1s;border:none;font-family:inherit}.chip-bank{background:var(--surface-hi);color:var(--text);border:2px solid var(--border);box-shadow:0 3px 0 var(--border)}.chip-bank:active:not(:disabled){transform:translateY(2px);box-shadow:0 1px 0 var(--border)}.chip-placed{background:#1cb0f622;color:var(--blue);border:2px solid #1CB0F655;box-shadow:0 3px #1cb0f633}.chip-placed:active:not(:disabled){transform:translateY(2px);box-shadow:0 1px #1cb0f633}.word-chip:disabled{opacity:.7;cursor:default}.btn-verify-payment{display:block;width:100%;padding:13px;border-radius:12px;border:2px solid var(--green);background:transparent;color:var(--green);font-size:.95rem;font-weight:800;cursor:pointer;transition:background .15s,color .15s}.btn-verify-payment:hover:not(:disabled){background:var(--green);color:#fff}.btn-verify-payment:disabled{opacity:.5;cursor:not-allowed}.redeem-verify-msg{font-size:.83rem;color:var(--text-light);text-align:center;margin:0}.btn-have-code{display:block;width:100%;margin-top:20px;padding:12px;border-radius:10px;border:1.5px dashed var(--border);background:transparent;color:var(--text-light);font-size:.88rem;cursor:pointer;transition:border-color .15s,color .15s}.btn-have-code:hover{border-color:var(--blue);color:var(--blue)}.payment-success-banner{position:fixed;top:0;left:0;right:0;z-index:9999;background:var(--green);color:#fff;display:flex;align-items:center;justify-content:space-between;padding:12px 16px;font-weight:700;font-size:.95rem;box-shadow:0 2px 8px #0000004d}.payment-success-banner button{background:none;border:none;color:#fff;font-size:1.1rem;cursor:pointer;padding:4px 8px;opacity:.8}.srs-buttons{display:flex;gap:10px;width:100%}.srs-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:14px 8px;border-radius:16px;border:2px solid var(--border);background:var(--surface-hi);cursor:pointer;font-family:inherit;transition:transform .1s,box-shadow .1s;min-height:72px}.srs-btn:active{transform:translateY(2px)}.srs-icon{font-size:22px}.srs-label{font-size:11px;font-weight:800;color:var(--text-light)}.srs-unknown{border-color:#ff4b4b55}.srs-unknown:active{background:#ff4b4b22}.srs-hard{border-color:#ff960055}.srs-hard:active{background:#ff960022}.srs-easy{border-color:#58cc0255}.srs-easy:active{background:#58cc0222}.fc-controls{display:flex;align-items:center;justify-content:space-between;width:100%;gap:10px}.fc-remaining{font-size:13px;color:var(--text-light);font-weight:600}.fc-shuffle{padding:10px 18px;border-radius:12px;border:2px solid var(--border);background:var(--surface-hi);color:var(--text);font-size:13px;font-weight:700;cursor:pointer;font-family:inherit}.fc-done-screen{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:32px 24px;text-align:center}.fc-done-icon{font-size:56px}.fc-done-title{font-size:24px;font-weight:900;color:var(--text);margin:0}.fc-done-sub{font-size:14px;color:var(--text-light);margin:0}.fc-done-stats{display:flex;gap:12px;margin:8px 0}.fc-done-stat{flex:1;background:var(--surface-hi);border:2px solid var(--border);border-radius:16px;padding:14px 10px;display:flex;flex-direction:column;align-items:center;gap:4px}.fc-done-num{font-size:24px;font-weight:900;color:var(--text)}.fc-done-label{font-size:11px;font-weight:700;color:var(--text-light)}.fc-easy-stat{border-color:#58cc0244}.fc-hard-stat{border-color:#ff960044}.fc-unk-stat{border-color:#ff4b4b44}.fc-easy-stat .fc-done-num{color:var(--green)}.fc-hard-stat .fc-done-num{color:#ff9600}.fc-unk-stat .fc-done-num{color:var(--red)}.blank-exercise{display:flex;flex-direction:column;align-items:center;gap:20px;padding:4px 0;width:100%}.blank-prompt{font-size:20px;font-weight:800;color:var(--text);text-align:center;margin:0;line-height:1.35}.blank-sentence-wrap{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:6px;font-size:18px;font-weight:700;color:var(--text);background:var(--surface-hi);border-radius:16px;padding:16px 20px;width:100%;line-height:2}.blank-sentence-part{white-space:pre-wrap}.blank-input{background:var(--surface);border:2.5px solid var(--border);border-radius:12px;padding:8px 14px;font-size:17px;font-weight:800;color:var(--text);font-family:inherit;text-align:center;min-width:80px;max-width:200px;width:auto;outline:none;transition:border-color .2s}.blank-input:focus{border-color:var(--blue)}.blank-input.blank-correct{border-color:var(--green);background:var(--tint-green);color:var(--green)}.blank-input.blank-wrong{border-color:var(--red);background:var(--tint-red);color:var(--red)}.blank-input::placeholder{color:var(--text-light);font-weight:600}.blank-speak{display:flex;justify-content:center}.blank-correction{font-size:14px;color:var(--red);font-weight:700;text-align:center;margin:0}.blank-submit{padding:14px 36px;border-radius:14px;border:none;background:var(--blue);color:#fff;font-size:16px;font-weight:800;cursor:pointer;font-family:inherit;box-shadow:0 4px #1490c8;transition:all .1s}.blank-submit:active{transform:translateY(2px);box-shadow:0 2px #1490c8}.blank-submit:disabled{opacity:.4;cursor:default;box-shadow:none}.ach-filters{display:flex;gap:6px;flex-wrap:wrap}.ach-filter-btn{padding:6px 14px;border-radius:99px;border:1.5px solid var(--border);background:var(--surface-hi);color:var(--text-light);font-size:12px;font-weight:700;cursor:pointer;font-family:inherit;white-space:nowrap;transition:all .15s}.ach-filter-btn.ach-filter-active{background:var(--blue);color:#fff;border-color:var(--blue)}.achievement-item.ach-locked{opacity:.55}.ach-desc{display:block}.french-hero{position:relative;background:linear-gradient(140deg,#0f2040,#152033 55%,#1a1a2e);overflow:hidden}.french-tricolor{height:4px;background:linear-gradient(90deg,#002395 33.33%,#ededf0 33.33%,#ededf0 66.66%,#ed2939 66.66%)}.french-hero-content{display:flex;align-items:center;justify-content:space-between;padding:18px 20px 22px}.french-hero-text{display:flex;flex-direction:column;gap:4px}.hero-bonjour{font-size:11px;font-weight:900;color:#6ba8e0;text-transform:uppercase;letter-spacing:2.5px;margin:0}.hero-title{font-size:24px;font-weight:900;color:#f1f5f9;margin:0;line-height:1.15}.hero-stats-row{display:flex;gap:12px;margin-top:6px}.hero-stat{font-size:13px;font-weight:700;color:#94a3b8}.french-hero-eiffel{font-size:62px;opacity:.75;filter:drop-shadow(0 6px 16px rgba(0,0,0,.5));-webkit-user-select:none;user-select:none;flex-shrink:0;line-height:1;margin-left:12px}.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:calc(58px + var(--sab));padding-bottom:var(--sab);background:#0e1520f7;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border-top:1px solid var(--border);display:flex;align-items:stretch;z-index:50;box-shadow:0 -4px 20px #00000059}.bnav-tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;background:none;border:none;cursor:pointer;padding:6px 4px;position:relative;-webkit-tap-highlight-color:transparent;transition:opacity .15s}.bnav-tab:active{opacity:.65}.bnav-icon{font-size:22px;line-height:1;transition:transform .2s cubic-bezier(.34,1.56,.64,1)}.bnav-label{font-size:10px;font-weight:700;color:var(--text-light);letter-spacing:.2px;transition:color .15s}.bnav-active .bnav-icon{transform:scale(1.18) translateY(-1px)}.bnav-active .bnav-label{color:var(--green)}.bnav-active:before{content:"";position:absolute;top:0;left:25%;right:25%;height:2.5px;background:var(--green);border-radius:0 0 4px 4px;box-shadow:0 1px 6px #58cc0280}@keyframes opt-pop{0%{transform:scale(1)}40%{transform:scale(1.05);box-shadow:0 0 0 6px #58cc022e}to{transform:scale(1)}}.option-btn.wrong-selected{background:var(--tint-red);border-color:var(--red);color:var(--red);box-shadow:0 4px #6b1010;animation:shake .4s ease}.category-card{box-shadow:0 2px 12px #00000040}.category-card:hover{box-shadow:0 4px 20px #00000059;transform:translateY(-2px)}.module-card{box-shadow:0 2px 10px #0000004d}.mod-progress-fill{position:relative;overflow:hidden}.mod-progress-fill:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.25) 50%,transparent 100%);animation:progress-shine 2s ease infinite}@keyframes progress-shine{0%{transform:translate(-100%)}to{transform:translate(300%)}}.map-header{background:linear-gradient(180deg,#1c2d4a 0%,var(--surface) 100%)}.map-banner{border-bottom:3px solid transparent;border-image:linear-gradient(90deg,#002395,#ededf0,#ed2939) 1}.achievement-toast{bottom:calc(var(--sab) + 70px)}@keyframes heart-break{0%{transform:scale(1.5) rotate(-20deg);filter:drop-shadow(0 0 8px #FF4B4B);opacity:1}25%{transform:scale(1.3) rotate(15deg)}55%{transform:scale(1.1) rotate(-8deg);opacity:.9}80%{transform:scale(.95) rotate(3deg);opacity:.6}to{transform:scale(1) rotate(0);opacity:.25;filter:grayscale(1)}}.heart.heart-breaking{animation:heart-break .7s cubic-bezier(.36,.07,.19,.97) forwards}.vocab-flip-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.vocab-flip-card{perspective:700px;cursor:pointer;height:130px;-webkit-tap-highlight-color:transparent}.vocab-flip-inner{position:relative;width:100%;height:100%;transition:transform .45s cubic-bezier(.4,0,.2,1);transform-style:preserve-3d}.vocab-flip-card.flipped .vocab-flip-inner{transform:rotateY(180deg)}.vocab-flip-front,.vocab-flip-back{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:var(--radius);backface-visibility:hidden;-webkit-backface-visibility:hidden;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:10px 12px;text-align:center;overflow:hidden}.vocab-flip-front{background:var(--surface);border:2px solid var(--border);transition:border-color .2s}.vocab-flip-card:not(.flipped):active .vocab-flip-front{border-color:var(--blue)}.vocab-flip-back{background:linear-gradient(135deg,#082840,#0d2035);border:2px solid var(--blue);transform:rotateY(180deg)}.vf-num{position:absolute;top:7px;left:9px;font-size:10px;font-weight:800;color:var(--text-light)}.vf-fr{font-size:17px;font-weight:900;color:var(--text);line-height:1.2}.vf-speak{position:absolute;bottom:6px;right:6px}.vf-tap-hint{position:absolute;bottom:7px;left:9px;font-size:9px;color:var(--text-light);font-weight:600;opacity:.7}.vf-pt{font-size:16px;font-weight:900;color:var(--text);line-height:1.2}.vf-sentence{font-size:11px;font-style:italic;color:var(--blue);line-height:1.3;max-width:100%}.vf-note{font-size:11px;color:var(--text-light);font-weight:600}.lb-podium{display:flex;align-items:flex-end;justify-content:center;gap:6px;padding:0 8px}.lb-podium-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;min-width:0}.lb-podium-crown{font-size:22px;animation:crown-bob 1.6s ease-in-out infinite}@keyframes crown-bob{0%,to{transform:translateY(0) rotate(-5deg)}50%{transform:translateY(-4px) rotate(5deg)}}.lb-podium-name{font-size:12px;font-weight:800;color:var(--text);text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%;margin:0}.lb-podium-me{color:var(--blue)}.lb-podium-xp{font-size:11px;font-weight:800;color:var(--gold);margin:0;white-space:nowrap}.lb-podium-step{width:100%;display:flex;align-items:flex-start;justify-content:center;padding-top:12px;border-radius:10px 10px 0 0}.lb-podium-medal{font-size:26px}.landing-screen{display:flex;flex-direction:column;min-height:100dvh;background:var(--bg);overflow-y:auto}.landing-night-hero{position:relative;background:linear-gradient(180deg,#020810,#071428 35%,#0c1e38 65%,#0e1520);overflow:hidden;padding-top:calc(var(--sat) + 0px)}.landing-bg-tower{position:absolute;bottom:-10px;right:-10px;font-size:200px;line-height:1;opacity:.08;filter:drop-shadow(0 0 40px #3b82f6);-webkit-user-select:none;user-select:none;pointer-events:none;transform:rotate(5deg)}.landing-top-stripe{display:flex;height:5px;width:100%}.landing-top-stripe span{flex:1;display:block}.landing-top-stripe span:nth-child(1){background:#002395}.landing-top-stripe span:nth-child(2){background:#ededed}.landing-top-stripe span:nth-child(3){background:#ed2939}.landing-hero-inner{display:flex;flex-direction:column;align-items:center;gap:20px;padding:48px 28px 52px;text-align:center;position:relative;z-index:1}.landing-logo{font-size:38px!important}.landing-headline{font-size:32px;font-weight:900;color:var(--text);line-height:1.2;margin:0}.landing-fr-em{font-style:normal;color:#60a5fa;text-shadow:0 0 20px rgba(96,165,250,.5)}.landing-sub{font-size:14px;color:var(--text-light);font-weight:600;margin:-6px 0 0}.btn-google-landing{width:100%;max-width:320px;font-size:17px;font-weight:800;padding:17px 20px;gap:12px;display:flex;align-items:center;justify-content:center;border-radius:14px;background:#fff;color:#1a1a1a;border:none;box-shadow:0 4px silver,0 6px 20px #0000004d;transition:transform .1s,box-shadow .1s}.btn-google-landing:active:not(:disabled){transform:translateY(3px);box-shadow:0 1px silver,0 2px 8px #0003}.btn-google-landing:disabled{opacity:.6}.landing-trust{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-light);font-weight:600;flex-wrap:wrap;justify-content:center}.landing-trust-dot{color:var(--border)}.landing-features-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:20px 16px 8px}.landing-feat{display:flex;flex-direction:column;align-items:flex-start;gap:4px;background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:16px 14px}.lf-icon{font-size:24px}.lf-title{font-size:14px;font-weight:800;color:var(--text);margin:0}.lf-sub{font-size:12px;color:var(--text-light);margin:0;line-height:1.35}.landing-levels{padding:16px 16px 8px}.landing-section-label{font-size:11px;font-weight:800;color:var(--text-light);text-transform:uppercase;letter-spacing:1px;margin:0 0 10px}.landing-levels-grid{display:flex;flex-direction:column;gap:8px}.landing-level-chip{display:flex;align-items:center;gap:12px;border-radius:14px;padding:14px 16px;border:1.5px solid var(--border)}.landing-level-chip span:first-child{font-size:24px;flex-shrink:0}.chip-label{font-size:15px;font-weight:800;color:var(--text);margin:0 0 2px}.chip-desc{font-size:12px;color:var(--text-light);margin:0}.chip-free{background:#58cc0210;border-color:#58cc0240}.chip-premium{background:var(--surface)}.landing-premium-banner{display:flex;align-items:center;gap:14px;margin:16px 16px 0;background:linear-gradient(135deg,#2d1060,#1a0a40);border:1.5px solid #a855f755;border-radius:18px;padding:18px 16px}.landing-premium-gem{font-size:28px;flex-shrink:0}.landing-premium-title{font-size:15px;font-weight:800;color:#e9d5ff;margin:0 0 3px}.landing-premium-price{font-size:13px;color:#a78bfa;margin:0}.landing-premium-price strong{color:#e9d5ff;font-size:15px}.landing-footer{display:flex;justify-content:center;padding:20px 16px calc(var(--sab) + 32px)}.btn-google-footer{width:100%;max-width:320px;font-size:16px;font-weight:800;padding:16px 20px;gap:12px;display:flex;align-items:center;justify-content:center;border-radius:14px;background:var(--green);color:#fff;border:none;box-shadow:0 4px 0 var(--green-dark);transition:transform .1s,box-shadow .1s}.btn-google-footer:active:not(:disabled){transform:translateY(3px);box-shadow:0 1px 0 var(--green-dark)}.btn-google-footer:disabled{opacity:.6}.btn-google-footer svg path{fill:#ffffffd9}.accent-kb{display:flex;flex-wrap:wrap;gap:6px;justify-content:center;padding:2px 0;width:100%}.accent-key{background:var(--surface-hi);border:1.5px solid var(--border);border-radius:9px;color:var(--text);font-size:16px;font-weight:700;font-family:inherit;padding:7px 11px;min-width:38px;cursor:pointer;transition:background .1s,color .1s,transform .08s;box-shadow:0 2px #00000059;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}.accent-key:active{background:var(--blue);color:#fff;border-color:var(--blue);transform:translateY(1px);box-shadow:0 1px #0000004d}.xp-animated .xp-amount{font-variant-numeric:tabular-nums;transition:none}.xp-animated{animation:xp-pop .4s cubic-bezier(.34,1.56,.64,1) .1s both}@keyframes xp-pop{0%{transform:scale(.6);opacity:0}to{transform:scale(1);opacity:1}}.weekly-chart{background:var(--surface);border:1.5px solid var(--border);border-radius:20px;padding:16px 16px 12px;display:flex;flex-direction:column;gap:12px}.weekly-chart-header{display:flex;justify-content:space-between;align-items:center;gap:8px}.weekly-chart-title{font-size:13px;font-weight:800;color:var(--text-light);text-transform:uppercase;letter-spacing:.5px}.weekly-chart-total{font-size:13px;font-weight:800;color:var(--gold)}.weekly-bars{display:flex;align-items:flex-end;gap:6px;height:80px}.weekly-bar-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;height:100%;justify-content:flex-end}.weekly-bar-xp{font-size:9px;font-weight:800;color:var(--gold);line-height:1;min-height:11px}.weekly-bar-track{flex:1;width:100%;background:var(--surface-hi);border-radius:6px;overflow:hidden;display:flex;align-items:flex-end;min-height:4px}.weekly-bar-fill{width:100%;min-height:4px;border-radius:6px;background:var(--border);transform-origin:bottom;animation:bar-grow .5s cubic-bezier(.34,1.3,.64,1) both}.weekly-bar-fill.bar-active{background:linear-gradient(180deg,#1cb0f6,#0d8fd4);box-shadow:0 0 8px #1cb0f659}.weekly-bar-fill.bar-today{background:linear-gradient(180deg,#58cc02,#46a302);box-shadow:0 0 10px #58cc0266}@keyframes bar-grow{0%{transform:scaleY(0)}to{transform:scaleY(1)}}.weekly-bar-label{font-size:10px;font-weight:700;color:var(--text-light);white-space:nowrap}.weekly-bar-label.label-today{color:var(--green);font-weight:900}.weekly-chart-sub{font-size:12px;color:var(--text-light);text-align:center;margin:0;font-weight:600}@keyframes screen-enter{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.category-screen,.map-screen,.levels-screen,.player-screen,.vocab-page,.lb-screen,.profile-screen,.completion-screen,.flashcard-screen,.dict-screen,.redeem-screen,.admin-screen,.onboard-screen,.placement-screen,.login-screen{animation:screen-enter .22s ease both}.landing-night-hero{animation:screen-enter .35s ease both}@keyframes mod-unlock{0%{transform:scale(.97);box-shadow:0 0 #ffc80099}30%{transform:scale(1.03);box-shadow:0 0 0 10px #ffc80040}60%{transform:scale(.99);box-shadow:0 0 0 18px #ffc80014}to{transform:scale(1);box-shadow:0 0 #ffc80000}}.module-card.mod-newly-unlocked{animation:mod-unlock .7s cubic-bezier(.34,1.56,.64,1) both;border-color:var(--gold)!important}.module-card.mod-newly-unlocked:after{content:"🔓 Desbloqueado!";position:absolute;top:-10px;right:12px;font-size:11px;font-weight:800;color:var(--gold);background:var(--bg);padding:2px 8px;border-radius:8px;border:1.5px solid var(--gold);animation:screen-enter .3s ease both;pointer-events:none}.module-card{position:relative}@keyframes typing-shake{0%,to{transform:translate(0)}18%{transform:translate(-7px)}36%{transform:translate(7px)}54%{transform:translate(-5px)}72%{transform:translate(5px)}90%{transform:translate(-2px)}}.typing-input-wrap.typing-shake-anim{animation:typing-shake .42s ease}.typing-input-wrap.typing-shake-anim .typing-input{border-color:var(--red)}.typing-retry-msg{font-size:13px;font-weight:700;color:#ff9600;text-align:center;margin:0;animation:screen-enter .2s ease both}.typing-hint{display:flex;align-items:center;justify-content:center;gap:6px;background:#ffc80015;border:1.5px solid #FFC80044;border-radius:12px;padding:10px 16px;font-size:14px;font-weight:700;color:var(--gold);animation:screen-enter .25s ease both}.typing-hint strong{color:#fff;font-size:18px;background:var(--gold);border-radius:6px;padding:1px 8px}.stat-accuracy{grid-column:1 / -1}.stat-acc-value{font-size:22px!important;letter-spacing:-.5px}.failed-hearts{display:flex;gap:12px;justify-content:center;margin-bottom:4px}@keyframes failed-heart-drop{0%{transform:translateY(-30px) scale(.5);opacity:0}55%{transform:translateY(6px) scale(1.2);opacity:1}75%{transform:translateY(-4px) scale(.95)}to{transform:translateY(0) scale(1);opacity:1}}.failed-heart-anim{font-size:44px;display:inline-block;animation:failed-heart-drop .55s cubic-bezier(.34,1.56,.64,1) both}.failed-title{font-size:28px;font-weight:900;color:var(--red);margin:0}.failed-sub{font-size:16px;color:var(--text-light);font-weight:600;margin:0}.listen-card{background:var(--surface);border:2px solid var(--border);border-radius:22px;padding:24px 20px 20px;display:flex;flex-direction:column;align-items:center;gap:16px;transition:border-color .2s,box-shadow .2s;width:100%;box-sizing:border-box}.listen-card-active{border-color:#1cb0f6;box-shadow:0 0 0 4px #1cb0f620}.btn-listen-big{display:flex;flex-direction:column;align-items:center;gap:8px;background:#1cb0f6;color:#fff;border:none;border-radius:18px;padding:18px 36px;cursor:pointer;transition:transform .12s,box-shadow .12s,background .2s;box-shadow:0 4px #0a7ab8;min-width:180px}.btn-listen-big:active{transform:translateY(3px);box-shadow:0 1px #0a7ab8}.btn-listen-big.speaking{background:#0a9fd4;animation:pulse-speak .9s ease infinite}.btn-listen-big.unplayed{animation:pulse-listen 1.8s ease infinite}.btn-listen-icon{font-size:32px;line-height:1}.btn-listen-label{font-size:14px;font-weight:800;letter-spacing:.3px}.listen-revealed{font-size:18px;font-weight:800;color:var(--text);margin:0;animation:screen-enter .25s ease both;letter-spacing:.5px}.sound-wave{display:flex;align-items:flex-end;gap:3px;height:28px}.wave-bar{width:4px;border-radius:2px;background:var(--border);height:var(--base-h, 8px);transition:background .2s}@keyframes wave-bounce{0%,to{transform:scaleY(.4)}50%{transform:scaleY(1)}}.sound-wave.wave-active .wave-bar{background:#1cb0f6;animation:wave-bounce .6s ease infinite}.ex-done-badge{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:800;border-radius:99px;padding:6px 16px;animation:screen-enter .3s ease both}.ex-done-check{font-size:52px;font-weight:900;color:var(--green);line-height:1;animation:bounce-in .45s cubic-bezier(.34,1.56,.64,1) both}.ex-done-title{font-size:24px;font-weight:900;color:var(--text);margin:0}.ex-dot.dot-pending{background:var(--surface-hi);border:2px solid var(--border)}.next-sub{font-size:12px;color:var(--text-light);font-weight:600}.ex-done-btn{font-size:17px;font-weight:800}.vocab-row+.vocab-row{border-top:1.5px solid var(--border)}@keyframes proceed-pulse{0%,to{box-shadow:0 4px 0 var(--green-dark)}50%{box-shadow:0 4px 0 var(--green-dark),0 0 0 8px #58cc0222}}.btn-proceed{animation:proceed-pulse 2s ease infinite}.btn-proceed:active{animation:none}.dict-stats-bar{display:flex;align-items:center;justify-content:center;gap:0;background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:14px 24px}.dict-stat-item{display:flex;flex-direction:column;align-items:center;gap:2px;flex:1}.dict-stat-num{font-size:26px;font-weight:900;color:var(--text);line-height:1}.dict-stat-label{font-size:12px;color:var(--text-light);font-weight:700;text-transform:uppercase;letter-spacing:.5px}.dict-stat-divider{width:1px;height:36px;background:var(--border);flex-shrink:0;margin:0 12px}.dict-search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);font-size:16px;pointer-events:none;line-height:1}.dict-search-wrap .dict-search{padding-left:42px}.dict-card{background:var(--surface);border:1px solid var(--border);border-left:4px solid;border-radius:14px;padding:14px 16px;display:flex;flex-direction:column;gap:6px;animation:screen-enter .18s ease both}.dict-card-top{display:flex;align-items:center;justify-content:space-between;gap:8px}.profile-nickname-wrap{display:flex;justify-content:center;width:100%}.profile-nickname-btn{display:inline-flex;align-items:center;gap:8px;background:var(--surface-hi);border:1.5px dashed var(--border);border-radius:12px;padding:10px 18px;cursor:pointer;transition:border-color .15s,background .15s;max-width:320px}.profile-nickname-btn:hover{border-color:#1cb0f6;background:var(--surface)}.profile-nickname-text{font-size:17px;font-weight:800;color:var(--text)}.profile-nickname-placeholder{font-size:15px;font-weight:600;color:var(--text-light);font-style:italic}.profile-nickname-edit-icon{font-size:15px;opacity:.6}.profile-nickname-edit{display:flex;align-items:center;gap:8px;width:100%;max-width:340px;animation:screen-enter .18s ease both}.profile-nickname-input{flex:1;background:var(--surface-hi);border:2px solid #1CB0F6;border-radius:12px;color:var(--text);font-size:16px;font-weight:700;padding:10px 14px;outline:none;min-width:0}.profile-nickname-input::placeholder{color:var(--text-light);font-weight:500}.profile-nickname-save{background:var(--green);color:#fff;border:none;border-radius:10px;font-size:14px;font-weight:800;padding:10px 16px;cursor:pointer;box-shadow:0 3px 0 var(--green-dark);white-space:nowrap;transition:transform .1s,box-shadow .1s}.profile-nickname-save:active{transform:translateY(2px);box-shadow:0 1px 0 var(--green-dark)}.profile-nickname-cancel{background:var(--surface-hi);color:var(--text-light);border:1.5px solid var(--border);border-radius:10px;font-size:16px;font-weight:700;padding:10px 13px;cursor:pointer;transition:background .1s}.profile-nickname-cancel:active{background:var(--border)}html.font-sm{font-size:13px}html.font-lg{font-size:18px}.settings-screen{display:flex;flex-direction:column;min-height:100dvh;background:var(--bg);animation:screen-enter .22s ease both}.settings-body{flex:1;display:flex;flex-direction:column;gap:16px;padding:20px 16px 40px;max-width:560px;width:100%;margin:0 auto;box-sizing:border-box}.settings-section{background:var(--surface);border:1px solid var(--border);border-radius:20px;overflow:hidden}.settings-section-title{font-size:13px;font-weight:800;color:var(--text-light);text-transform:uppercase;letter-spacing:.8px;padding:14px 18px 10px;margin:0;border-bottom:1px solid var(--border)}.settings-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 18px;border-bottom:1px solid var(--border)}.settings-row:last-child{border-bottom:none}.settings-row-col{flex-direction:column;align-items:flex-start}.settings-row-text{display:flex;flex-direction:column;gap:2px;flex:1}.settings-row-label{font-size:15px;font-weight:700;color:var(--text)}.settings-row-desc{font-size:12px;color:var(--text-light);font-weight:500}.settings-toggle{position:relative;width:52px;height:28px;border-radius:14px;border:none;cursor:pointer;transition:background .25s;flex-shrink:0;padding:0}.settings-toggle.toggle-on{background:var(--green)}.settings-toggle.toggle-off{background:var(--surface-hi);border:1.5px solid var(--border)}.toggle-knob{position:absolute;top:3px;width:22px;height:22px;border-radius:11px;background:#fff;box-shadow:0 2px 4px #0000004d;transition:left .25s cubic-bezier(.34,1.56,.64,1)}.toggle-on .toggle-knob{left:27px}.toggle-off .toggle-knob{left:3px}.font-size-picker{display:flex;gap:8px;width:100%;margin-top:10px}.font-size-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:5px;padding:12px 8px;border-radius:14px;border:2px solid var(--border);background:var(--surface-hi);cursor:pointer;transition:border-color .15s,background .15s}.font-size-btn.font-size-active{border-color:var(--green);background:#58cc0218}.font-size-sample{font-weight:900;color:var(--text);line-height:1}.font-size-label{font-size:11px;font-weight:700;color:var(--text-light);text-transform:uppercase;letter-spacing:.5px}.settings-info{padding:14px 18px;text-align:center}.settings-info-text{font-size:13px;color:var(--text-light);margin:3px 0}.header-settings-btn{background:none;border:none;font-size:20px;cursor:pointer;padding:4px 6px;border-radius:10px;opacity:.7;transition:opacity .15s,background .15s}.header-settings-btn:hover{opacity:1;background:var(--surface-hi)}.btn-settings-profile{width:100%;max-width:320px;padding:14px;border-radius:var(--radius);border:2px solid var(--border);background:var(--surface);color:var(--text);font-size:15px;font-weight:700;cursor:pointer;transition:background .12s,border-color .12s}.btn-settings-profile:hover{background:var(--surface-hi)}.btn-settings-profile:active{background:var(--border)}.profile-rank-wrap{display:flex;flex-direction:column;align-items:center;gap:10px;width:100%}.profile-rank-badge{display:inline-flex;align-items:center;gap:8px;border:2px solid;border-radius:99px;padding:8px 22px;animation:screen-enter .3s ease both}.profile-rank-icon{font-size:22px;line-height:1}.profile-rank-label{font-size:15px;font-weight:900;letter-spacing:.3px}.profile-rank-progress{display:flex;flex-direction:column;gap:5px;width:100%;max-width:280px}.profile-rank-bar{height:8px;background:var(--surface-hi);border-radius:4px;overflow:hidden;border:1px solid var(--border)}.profile-rank-bar-fill{height:100%;border-radius:4px;transition:width .6s ease}.profile-rank-hint{font-size:12px;color:var(--text-light);font-weight:600;text-align:center}.profile-rank-max{font-size:13px;font-weight:700;color:var(--gold)}.lb-rank-chip{font-size:16px;margin-right:4px;line-height:1}.lb-body-hidden{display:none}.lb-locked-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;padding:60px 32px;text-align:center;animation:screen-enter .25s ease both}.lb-locked-icon{font-size:64px}.lb-locked-title{font-size:24px;font-weight:900;color:var(--text);margin:0}.lb-locked-desc{font-size:15px;color:var(--text-light);font-weight:600;line-height:1.5;max-width:300px;margin:0}.lb-locked-progress{display:flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:14px 18px;flex-wrap:wrap;justify-content:center}.lb-locked-step{font-size:13px;font-weight:800;border-radius:8px;padding:4px 10px}.lb-step-done{background:#58cc0222;color:var(--green);border:1px solid #58CC0244}.lb-step-next{background:#ffd70022;color:var(--gold);border:1px solid #FFD70044}.lb-locked-arrow{font-size:14px;color:var(--text-light);font-weight:700}.bnav-icon-wrap{position:relative;display:inline-flex;align-items:center;justify-content:center}.bnav-lock-badge{position:absolute;top:-6px;right:-8px;font-size:10px;line-height:1}.bnav-locked .bnav-icon,.bnav-locked .bnav-label{opacity:.5}.matching-exercise{display:flex;flex-direction:column;gap:20px;width:100%}.matching-cols{display:grid;grid-template-columns:1fr auto 1fr;gap:0 6px;align-items:start}.matching-col{display:flex;flex-direction:column;gap:10px}.matching-chip{width:100%;min-height:52px;padding:10px 12px;border-radius:14px;border:2px solid var(--border);background:var(--surface);color:var(--text);font-size:14px;font-weight:700;cursor:pointer;text-align:center;transition:border-color .15s,background .15s,color .15s,opacity .2s;line-height:1.3;word-break:break-word}.matching-chip.chip-selected{border-color:#1cb0f6;background:#1cb0f618;color:#1cb0f6;box-shadow:0 0 0 3px #1cb0f622}.matching-chip.chip-done{border-color:var(--green);background:#58cc0218;color:var(--green);opacity:.7;pointer-events:none;text-decoration:line-through}.matching-chip.chip-wrong{border-color:var(--red);background:#ff4b4b18;color:var(--red)}.matching-chip.chip-inactive{opacity:.4}@keyframes chip-shake{0%,to{transform:translate(0)}20%{transform:translate(-6px)}40%{transform:translate(6px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}.matching-chip.chip-shake{animation:chip-shake .42s ease}.matching-divider{display:flex;flex-direction:column;gap:10px;align-items:center}.matching-line{width:2px;height:52px;background:var(--border);border-radius:1px;transition:background .3s}.matching-line.line-done{background:var(--green)}.matching-success{text-align:center;font-size:16px;font-weight:800;color:var(--green);animation:bounce-in .4s cubic-bezier(.34,1.56,.64,1) both;padding:12px;background:#58cc0212;border:1.5px solid #58CC0244;border-radius:14px}
