:root{--font-main: "Nunito", "Comic Sans MS", cursive;--color-pinky: #FF6B6B;--color-ring: #FF9F43;--color-middle: #54A0FF;--color-index: #00B894;--color-thumb: #AAAAAA;--color-sky: #87CEEB;--color-lavender: #C9B1FF;--color-cream: #FFF9F0;--color-card: #FFFFFF;--color-border: #E8E0F0;--color-text: #2D1B69;--color-text-soft: #7B6BA8;--color-correct: #00C896;--color-wrong: #FF4757;--color-gold: #FFD700;--color-gold-2: #FFA502;--grad-title: linear-gradient(160deg, #87CEEB 0%, #C9B1FF 60%, #FFB3D9 100%);--grad-primary: linear-gradient(135deg, #FF6B6B 0%, #FF9F43 100%);--grad-correct: linear-gradient(135deg, #00C896 0%, #00B894 100%);--grad-game-bg: linear-gradient(160deg, #F0F7FF 0%, #FFF0F7 100%);--radius-sm: 8px;--radius-md: 16px;--radius-lg: 24px;--radius-xl: 32px;--radius-pill: 999px;--shadow-card: 0 4px 20px rgba(100, 60, 180, .12);--shadow-key: 0 4px 0 0 rgba(0,0,0,.18);--shadow-btn: 0 6px 0 0 rgba(0,0,0,.15)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;overflow:hidden}body{font-family:var(--font-main);background:var(--grad-title);color:var(--color-text);-webkit-font-smoothing:antialiased}#root{height:100%}.app{height:100%;display:flex;flex-direction:column;overflow:hidden;position:relative}.screen{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;overflow-y:auto;overflow-x:hidden}.title-screen{background:var(--grad-title);justify-content:center;gap:0;position:relative}.title-screen:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(circle at 20% 20%,rgba(255,255,255,.25) 0%,transparent 40%),radial-gradient(circle at 80% 70%,rgba(255,255,255,.2) 0%,transparent 35%),radial-gradient(circle at 50% 50%,rgba(255,255,255,.1) 0%,transparent 60%);pointer-events:none}.title-content{display:flex;flex-direction:column;align-items:center;gap:18px;padding:40px 24px 24px;flex:1;justify-content:center;position:relative;z-index:1}.title-emoji{font-size:80px;line-height:1;filter:drop-shadow(0 8px 16px rgba(100,60,180,.2));animation:floatBob 3s ease-in-out infinite}.title-heading{font-size:clamp(52px,10vw,80px);font-weight:900;line-height:1.05;text-align:center;color:#fff;text-shadow:0 4px 0 rgba(100,60,180,.25),0 8px 24px rgba(100,60,180,.2);letter-spacing:-1px;animation:bounceIn .7s cubic-bezier(.34,1.56,.64,1) both}.title-sub{font-size:18px;font-weight:600;color:#ffffffe6;text-align:center;max-width:320px;line-height:1.5;text-shadow:0 2px 8px rgba(100,60,180,.2)}.title-keys{display:flex;gap:6px;padding:20px 24px;flex-wrap:wrap;justify-content:center;position:relative;z-index:1}.deco-key{width:44px;height:44px;background:#ffffffd9;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:800;color:var(--color-text);box-shadow:0 4px #643cb433;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:popIn .4s cubic-bezier(.34,1.56,.64,1) both}.deco-key:nth-child(1){animation-delay:.05s}.deco-key:nth-child(2){animation-delay:.1s}.deco-key:nth-child(3){animation-delay:.15s}.deco-key:nth-child(4){animation-delay:.2s}.deco-key:nth-child(5){animation-delay:.25s}.deco-key:nth-child(6){animation-delay:.3s}.deco-key:nth-child(7){animation-delay:.35s}.deco-key:nth-child(8){animation-delay:.4s}.deco-key:nth-child(9){animation-delay:.45s}.level-select-screen{background:var(--grad-game-bg);padding:24px 16px 32px;gap:20px}.screen-title{font-size:32px;font-weight:900;color:var(--color-text);text-align:center;letter-spacing:-.5px}.level-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:14px;width:100%;max-width:700px}.level-card{background:var(--color-card);border:3px solid var(--color-border);border-radius:var(--radius-lg);padding:18px 12px 16px;display:flex;flex-direction:column;align-items:center;gap:6px;cursor:pointer;transition:transform .15s cubic-bezier(.34,1.56,.64,1),box-shadow .15s ease,border-color .15s ease;box-shadow:var(--shadow-card);font-family:var(--font-main);text-align:center;position:relative;overflow:hidden}.level-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--grad-primary);opacity:0;transition:opacity .2s}.level-card-unlocked:hover{transform:translateY(-4px) scale(1.03);box-shadow:0 8px 28px #643cb42e;border-color:var(--color-lavender)}.level-card-unlocked:hover:before{opacity:1}.level-card-unlocked:active{transform:translateY(0) scale(.97)}.level-card-done{border-color:#c3f0e3;background:linear-gradient(135deg,#f0fff8,#fff)}.level-card-locked{opacity:.55;cursor:not-allowed;background:#f7f5ff}.level-number{position:absolute;top:8px;left:12px;font-size:11px;font-weight:800;color:var(--color-text-soft);letter-spacing:.5px}.level-emoji{font-size:36px;line-height:1}.level-name{font-size:13px;font-weight:800;color:var(--color-text);line-height:1.3}.level-new-keys{font-size:11px;font-weight:700;color:var(--color-text-soft);letter-spacing:1px;background:#f0edf8;padding:3px 8px;border-radius:var(--radius-pill)}.level-stars{display:flex;gap:2px;margin-top:4px}.star-on{color:var(--color-gold);font-size:16px;text-shadow:0 2px 4px rgba(255,160,0,.4)}.star-off{color:#d8d0e8;font-size:16px}.level-intro-screen{background:var(--grad-game-bg);padding:24px 20px 40px;gap:0}.intro-content{display:flex;flex-direction:column;align-items:center;gap:16px;width:100%;max-width:600px}.intro-emoji{font-size:64px;line-height:1;animation:floatBob 3s ease-in-out infinite}.intro-title{font-size:28px;font-weight:900;color:var(--color-text);text-align:center;letter-spacing:-.5px}.intro-subtitle{font-size:20px;font-weight:700;color:var(--color-text-soft);text-align:center}.intro-desc{font-size:16px;font-weight:600;color:var(--color-text-soft);text-align:center;max-width:420px;line-height:1.6;background:#fff;border-radius:var(--radius-md);padding:14px 20px;box-shadow:var(--shadow-card)}.new-keys-showcase{display:flex;flex-direction:column;align-items:center;gap:12px;width:100%}.new-keys-label{font-size:14px;font-weight:800;color:var(--color-text-soft);text-transform:uppercase;letter-spacing:1px}.new-keys-row{display:flex;gap:10px;flex-wrap:wrap;justify-content:center}.showcase-key{width:58px;height:58px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:26px;font-weight:900;color:#fff;box-shadow:0 5px #0003;text-shadow:0 2px 4px rgba(0,0,0,.15);animation:popIn .5s cubic-bezier(.34,1.56,.64,1) both}.finger-legend{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;background:#fff;padding:12px 20px;border-radius:var(--radius-xl);box-shadow:var(--shadow-card)}.legend-item{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:700;color:var(--color-text-soft);text-transform:capitalize}.legend-dot{width:14px;height:14px;border-radius:50%;flex-shrink:0;box-shadow:0 2px 4px #00000026}.intro-keyboard{transform:scale(.9);transform-origin:center top}.game-outer{width:100%;height:100%;display:flex;flex-direction:column;background:var(--grad-game-bg);overflow:hidden}.phase-indicator{display:flex;justify-content:center;gap:8px;padding:12px 0 8px;flex-shrink:0}.phase-dot{width:10px;height:10px;border-radius:50%;transition:all .3s ease}.phase-dot.phase-done{background:var(--color-correct);box-shadow:0 0 0 2px #00c8964d}.phase-dot.phase-active{background:var(--color-ring);width:28px;border-radius:5px;box-shadow:0 0 0 3px #ff9f434d}.phase-dot.phase-pending{background:#d8d0e8}.game-wrap{flex:1;display:flex;flex-direction:column;overflow:hidden;padding:0 16px 8px;gap:10px;position:relative}.game-header{display:flex;align-items:center;gap:12px;flex-shrink:0;flex-wrap:wrap}.game-title{font-size:20px;font-weight:900;color:var(--color-text);white-space:nowrap}.finger-hint{text-align:center;font-size:15px;font-weight:700;color:var(--color-text-soft);height:22px;flex-shrink:0}.keyboard-wrap{flex-shrink:0;display:flex;justify-content:center}.keyboard{display:flex;flex-direction:column;gap:5px;background:#ffffffb3;padding:12px 14px;border-radius:var(--radius-xl);box-shadow:var(--shadow-card);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.keyboard-row{display:flex;gap:5px;justify-content:center}.keyboard-row-1{padding-left:20px}.keyboard-row-2{padding-left:28px}.keyboard-row-3{padding-left:0}.key{width:42px;height:42px;border-radius:var(--radius-sm);display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;transition:transform .1s ease,box-shadow .1s ease;-webkit-user-select:none;user-select:none;flex-shrink:0}.key-label{font-family:var(--font-main);font-size:15px;font-weight:800;line-height:1}.key-dim{background:#e8e4f0;box-shadow:0 3px #c8c0d8}.key-dim .key-label{color:#b0a8c4}.key-learned{box-shadow:0 4px #0003;transition:transform .15s ease}.key-learned .key-label{color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.2)}.key-target{transform:scale(1.15) translateY(-3px)!important;box-shadow:0 0 0 3px #fff,0 0 0 5px #fffc,0 6px 20px #643cb459!important;background:#fff!important;animation:pulseGlow .9s ease-in-out infinite alternate!important;z-index:2}.key-target .key-label{color:var(--color-text)!important}.key-shift{width:58px;border-radius:var(--radius-sm)}.key-shift-active{background:var(--color-ring)!important;box-shadow:0 4px #0003,0 0 0 3px #ff9f4366!important;animation:pulseGlow .9s ease-in-out infinite alternate}.key-label-shift{font-size:13px!important}.key-bump{position:absolute;bottom:7px;left:50%;transform:translate(-50%);width:6px;height:3px;background:#ffffffb3;border-radius:2px}.key-dim .key-bump{background:#00000026}@media(max-width:500px){.key{width:32px;height:34px}.key-label{font-size:11px}.keyboard-row:nth-child(2){padding-left:14px}.keyboard-row:nth-child(3){padding-left:28px}}.keyhunt-target{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px}.target-letter{font-size:clamp(90px,18vw,140px);font-weight:900;line-height:1;color:var(--color-text);background:#fff;width:min(200px,50vw);height:min(200px,50vw);border-radius:var(--radius-xl);display:flex;align-items:center;justify-content:center;box-shadow:0 8px 32px #643cb426;transition:background .1s;letter-spacing:-4px;position:relative}.target-letter:before{content:"";position:absolute;bottom:0;left:0;right:0;height:8px;background:var(--grad-primary);border-radius:0 0 calc(var(--radius-xl) - 2px) calc(var(--radius-xl) - 2px)}.rain-stats{display:flex;align-items:center;gap:10px;flex:1;flex-wrap:wrap}.rain-score{font-size:18px;font-weight:900;color:var(--color-text);white-space:nowrap}.timer-bar{flex:1;min-width:80px;height:12px;background:#e8e0f0;border-radius:var(--radius-pill);overflow:hidden}.timer-fill{height:100%;background:var(--grad-primary);border-radius:var(--radius-pill);transition:width .25s linear}.rain-lives{font-size:18px;white-space:nowrap}.rain-field{flex:1;position:relative;background:#fff;border-radius:var(--radius-xl);overflow:hidden;box-shadow:inset 0 2px 12px #643cb414,var(--shadow-card);min-height:180px}.rain-field:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(200,190,230,.15) 1px,transparent 1px);background-size:100% 40px;pointer-events:none}.rain-letter{position:absolute;font-size:clamp(28px,6vw,40px);font-weight:900;color:var(--color-text);background:#fff;border:3px solid var(--color-lavender);border-radius:var(--radius-sm);width:46px;height:46px;display:flex;align-items:center;justify-content:center;box-shadow:0 3px #643cb426;transform:translate(-50%);pointer-events:none;transition:opacity .15s}.worddash-display{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px}.word-display{display:flex;gap:4px;flex-wrap:wrap;justify-content:center;background:#fff;padding:24px 32px;border-radius:var(--radius-xl);box-shadow:var(--shadow-card);min-width:200px;min-height:100px;align-items:center}.char-done{font-size:clamp(36px,8vw,56px);font-weight:900;color:var(--color-correct);transition:color .1s}.char-next{font-size:clamp(36px,8vw,56px);font-weight:900;color:var(--color-text);position:relative;animation:charPulse .7s ease-in-out infinite alternate}.char-next:after{content:"";position:absolute;bottom:-4px;left:0;right:0;height:4px;background:var(--color-ring);border-radius:2px;animation:charPulse .7s ease-in-out infinite alternate}.char-pending{font-size:clamp(36px,8vw,56px);font-weight:900;color:#c8c0d8}.char-space{font-size:.45em;opacity:.35;margin:0 4px;align-self:center}.char-space.char-next{opacity:1;font-size:.55em;color:var(--color-ring);outline:2px solid var(--color-ring);border-radius:4px;padding:2px 4px;background:#ff9f4326;animation:charPulse .7s ease-in-out infinite alternate}.char-space.char-done{opacity:.2;color:var(--color-correct)}.combo-badge{font-size:20px;font-weight:900;color:#fff;background:var(--grad-primary);padding:6px 20px;border-radius:var(--radius-pill);box-shadow:0 4px 12px #ff6b6b66;animation:popIn .3s cubic-bezier(.34,1.56,.64,1)}.fact-display{flex:1;display:flex;flex-direction:column;gap:12px;justify-content:center}.subject-badge{display:inline-flex;align-items:center;gap:6px;font-size:14px;font-weight:800;padding:6px 16px;border-radius:var(--radius-pill);border:2px solid;align-self:flex-start;text-transform:uppercase;letter-spacing:.5px}.fact-text{background:#fff;border-radius:var(--radius-xl);padding:20px 24px;box-shadow:var(--shadow-card);font-size:clamp(18px,4vw,24px);font-weight:700;line-height:1.7;display:block;word-break:break-word}.fact-char{font-family:var(--font-main);font-size:inherit;font-weight:inherit;line-height:inherit;display:inline;transition:color .05s}.fact-char-done{color:#00a87a;font-weight:700}.fact-char-next{color:#1a1a3e;background:gold;border-radius:4px;padding:2px 3px;margin:0 1px;font-weight:800;box-shadow:0 3px #e6a800;animation:charPulse .65s ease-in-out infinite alternate}.fact-char-pending{color:#4b3b80}.fact-char-new{color:#8b80c4;background:#54a0ff14;border-radius:2px}.fact-progress-bar{height:8px;background:#e8e0f0;border-radius:var(--radius-pill);overflow:hidden}.fact-progress-fill{height:100%;background:var(--grad-correct);border-radius:var(--radius-pill);transition:width .15s ease-out}.progress-wrap{display:flex;align-items:center;gap:8px;flex:1;min-width:0}.progress-label{font-size:13px;font-weight:700;color:var(--color-text-soft);white-space:nowrap}.progress-track{flex:1;height:12px;background:#e8e0f0;border-radius:var(--radius-pill);overflow:hidden}.progress-fill{height:100%;background:var(--grad-correct);border-radius:var(--radius-pill);transition:width .3s cubic-bezier(.34,1.56,.64,1)}.progress-count{font-size:13px;font-weight:800;color:var(--color-text-soft);white-space:nowrap}.feedback-burst{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%) scale(.5);font-size:72px;font-weight:900;border-radius:50%;width:120px;height:120px;display:flex;align-items:center;justify-content:center;pointer-events:none;z-index:100;animation:burstPop .6s cubic-bezier(.34,1.56,.64,1) forwards}.feedback-correct{background:radial-gradient(circle,#afffdf,#00c896);color:#fff;box-shadow:0 0 40px #00c89680}.feedback-wrong{background:radial-gradient(circle,#ffd0d0,#ff4757);color:#fff;box-shadow:0 0 40px #ff475780}.level-complete-screen{background:linear-gradient(160deg,#fff9e6,#fff0f7 60%,#f0f7ff);justify-content:center}.complete-content{display:flex;flex-direction:column;align-items:center;gap:20px;padding:40px 24px;text-align:center}.complete-emoji{font-size:80px;line-height:1;animation:floatBob 2s ease-in-out infinite}.complete-title{font-size:40px;font-weight:900;color:var(--color-text);letter-spacing:-1px;animation:bounceIn .6s cubic-bezier(.34,1.56,.64,1)}.complete-level{font-size:20px;font-weight:700;color:var(--color-text-soft)}.stars-display{display:flex;gap:8px;animation:bounceIn .6s cubic-bezier(.34,1.56,.64,1) .1s both}.big-star{font-size:56px;line-height:1;transition:all .3s}.star-earned{color:var(--color-gold);text-shadow:0 4px 12px rgba(255,160,0,.5);animation:starPop .5s cubic-bezier(.34,1.56,.64,1) both}.star-earned:nth-child(1){animation-delay:.2s}.star-earned:nth-child(2){animation-delay:.35s}.star-earned:nth-child(3){animation-delay:.5s}.star-empty{color:#d8d0e8}.accuracy-display{display:flex;flex-direction:column;align-items:center;background:#fff;padding:16px 40px;border-radius:var(--radius-xl);box-shadow:var(--shadow-card)}.accuracy-number{font-size:52px;font-weight:900;color:var(--color-text);line-height:1;letter-spacing:-2px}.accuracy-label{font-size:14px;font-weight:700;color:var(--color-text-soft);text-transform:uppercase;letter-spacing:1px}.praise-text{font-size:20px;font-weight:700;color:var(--color-text-soft)}.complete-buttons{display:flex;gap:12px;flex-wrap:wrap;justify-content:center}.btn{font-family:var(--font-main);font-size:16px;font-weight:800;padding:12px 28px;border-radius:var(--radius-pill);border:none;cursor:pointer;transition:transform .12s cubic-bezier(.34,1.56,.64,1),box-shadow .12s ease;display:inline-flex;align-items:center;gap:6px;letter-spacing:.3px;white-space:nowrap;text-decoration:none}.btn:active{transform:scale(.95) translateY(3px)!important;box-shadow:none!important}.btn-primary{background:var(--grad-primary);color:#fff;box-shadow:var(--shadow-btn),0 4px 20px #ff6b6b66}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px #0000001f,0 6px 24px #ff6b6b80}.btn-secondary{background:#fff;color:var(--color-text);box-shadow:0 4px 0 var(--color-border),var(--shadow-card);border:2px solid var(--color-border)}.btn-secondary:hover{transform:translateY(-2px);box-shadow:0 6px 0 var(--color-lavender),0 4px 20px #643cb426;border-color:var(--color-lavender)}.btn-giant{font-size:22px;padding:18px 48px;box-shadow:0 8px #00000026,0 8px 30px #ff6b6b73}.btn-giant:hover{transform:translateY(-4px);box-shadow:0 12px #0000001f,0 12px 40px #ff6b6b80}@keyframes bounceIn{0%{transform:scale(.3);opacity:0}60%{transform:scale(1.1);opacity:1}80%{transform:scale(.95)}to{transform:scale(1)}}@keyframes popIn{0%{transform:scale(0);opacity:0}70%{transform:scale(1.15);opacity:1}to{transform:scale(1)}}@keyframes floatBob{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes bounce{0%,to{transform:translateY(0)}30%{transform:translateY(-16px) scale(1.08)}60%{transform:translateY(-6px)}80%{transform:translateY(-10px)}}@keyframes shake{0%,to{transform:translate(0)}15%{transform:translate(-10px) rotate(-2deg)}35%{transform:translate(10px) rotate(2deg)}55%{transform:translate(-6px) rotate(-1deg)}75%{transform:translate(6px) rotate(1deg)}}@keyframes pulseGlow{0%{box-shadow:0 0 0 3px #fff,0 0 0 5px #ff9f4380,0 6px 20px #643cb44d}to{box-shadow:0 0 0 3px #fff,0 0 0 8px #ff9f43cc,0 10px 30px #ff9f4366}}@keyframes charPulse{0%{opacity:1}to{opacity:.55}}@keyframes burstPop{0%{transform:translate(-50%,-50%) scale(.3);opacity:1}50%{transform:translate(-50%,-50%) scale(1.2);opacity:1}to{transform:translate(-50%,-50%) scale(1.5);opacity:0}}@keyframes starPop{0%{transform:scale(0) rotate(-20deg);opacity:0}60%{transform:scale(1.3) rotate(5deg);opacity:1}to{transform:scale(1) rotate(0);opacity:1}}.bounce{animation:bounce .5s cubic-bezier(.34,1.56,.64,1)}.shake{animation:shake .45s ease-in-out}.title-buttons{display:flex;flex-direction:column;gap:14px;align-items:center}.btn-topics{background:linear-gradient(135deg,#5f27cd,#7b68ee);color:#fff;box-shadow:0 6px #00000026,0 4px 20px #5f27cd66}.btn-topics:hover{transform:translateY(-2px);box-shadow:0 8px #0000001f,0 6px 24px #5f27cd80}.btn-back{background:none;border:none;font-family:var(--font-main);font-size:15px;font-weight:700;color:var(--color-text-soft);cursor:pointer;padding:6px 10px;border-radius:var(--radius-pill);transition:background .15s;flex-shrink:0}.btn-back:hover{background:#643cb414}.btn-back-light{color:#fffc}.btn-back-light:hover{background:#ffffff26}.level-select-top{display:flex;align-items:center;gap:12px;width:100%;max-width:700px}.level-select-top .screen-title{flex:1;text-align:center}.topic-select-screen{background:linear-gradient(160deg,#1a1a3e,#2d1b69 60%,#1a1a3e);padding:20px 16px 32px;gap:16px;align-items:stretch}.topic-select-header{display:flex;align-items:center;gap:12px}.topic-select-header .screen-title{flex:1;text-align:center;color:#fff}.topic-select-sub{font-size:18px;font-weight:600;color:#ffffffbf;text-align:center;max-width:500px;align-self:center}.topic-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;width:100%;max-width:800px;align-self:center}.topic-card{background:#ffffff14;border:2px solid rgba(255,255,255,.15);border-radius:var(--radius-xl);padding:28px 24px 22px;display:flex;flex-direction:column;align-items:flex-start;gap:10px;cursor:pointer;text-align:left;font-family:var(--font-main);transition:transform .15s cubic-bezier(.34,1.56,.64,1),border-color .15s,background .15s;position:relative;overflow:hidden}.topic-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--topic-color, #7B68EE);opacity:0;transition:opacity .2s}.topic-card:hover{transform:translateY(-4px);border-color:var(--topic-color, #7B68EE);background:#ffffff21}.topic-card:hover:before{opacity:1}.topic-card-emoji{font-size:64px;line-height:1}.topic-card-name{font-size:24px;font-weight:900;color:#fff;letter-spacing:-.5px}.topic-card-desc{font-size:15px;font-weight:600;color:#ffffffb3;line-height:1.55}.topic-card-footer{display:flex;justify-content:space-between;width:100%;margin-top:4px}.topic-articles-count{font-size:12px;font-weight:700;color:#ffffff80;text-transform:uppercase;letter-spacing:.5px}.topic-progress-text{font-size:12px;font-weight:700;color:var(--topic-color, #7B68EE)}.topic-progress-bar{width:100%;height:4px;background:#ffffff1a;border-radius:2px;overflow:hidden}.topic-progress-fill{height:100%;background:var(--topic-color, #7B68EE);border-radius:2px;transition:width .4s ease}.article-select-screen{background:var(--grad-game-bg);padding:0 0 32px;gap:0;align-items:stretch}.article-select-header{display:flex;align-items:center;gap:12px;padding:16px 20px;flex-shrink:0}.article-select-title{display:flex;align-items:center;gap:10px;font-size:24px;font-weight:900;color:#fff;flex:1;justify-content:center}.article-list{display:flex;flex-direction:column;gap:14px;padding:20px 16px;overflow-y:auto}.article-card{background:#fff;border:2px solid var(--color-border);border-radius:var(--radius-lg);padding:20px;display:flex;align-items:center;gap:18px;cursor:pointer;text-align:left;font-family:var(--font-main);transition:transform .12s cubic-bezier(.34,1.56,.64,1),box-shadow .12s,border-color .12s;box-shadow:var(--shadow-card)}.article-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px #643cb426;border-color:var(--topic-accent, var(--color-lavender))}.article-card-done{border-color:#c3f0e3;background:linear-gradient(135deg,#f0fff8,#fff)}.article-emoji{font-size:44px;line-height:1;flex-shrink:0}.article-card-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.article-card-title{font-size:20px;font-weight:800;color:var(--color-text)}.article-card-desc{font-size:15px;font-weight:600;color:var(--color-text-soft);line-height:1.45}.article-card-progress{display:flex;align-items:center;gap:8px;margin-top:4px}.article-para-track{display:flex;gap:4px}.article-para-pip{width:14px;height:8px;border-radius:4px;background:#e8e0f0;transition:background .2s}.article-para-pip.pip-done{background:var(--color-correct)}.article-para-count{font-size:13px;font-weight:700;color:var(--color-text-soft)}.article-card-right{flex-shrink:0}.article-badge-done{font-size:24px;color:var(--color-gold);text-shadow:0 2px 6px rgba(255,160,0,.4)}.article-badge-wip{font-size:18px;color:var(--color-correct)}.article-badge-new{font-size:11px;font-weight:800;color:#fff;background:var(--color-ring);padding:3px 8px;border-radius:var(--radius-pill)}.article-typer-screen{background:var(--grad-game-bg);padding:0;gap:0;align-items:stretch}.typer-header{display:flex;align-items:center;padding:12px 16px;gap:10px;flex-shrink:0}.typer-header-centre{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;min-width:0}.typer-article-title{font-size:16px;font-weight:800;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.typer-nav{display:flex;align-items:center;gap:8px}.typer-nav-btn{background:#fff3;border:none;color:#fff;font-size:20px;font-weight:900;width:28px;height:28px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s;font-family:var(--font-main);flex-shrink:0;line-height:1;padding:0}.typer-nav-btn:hover:not(:disabled){background:#fff6}.typer-nav-btn:disabled{opacity:.25;cursor:default}.typer-para-pips{display:flex;gap:5px}.typer-pip{width:20px;height:5px;border-radius:3px;background:#fff3;transition:all .3s}.typer-pip.pip-done{background:var(--color-correct)}.typer-pip.pip-current{background:#ffffffe6;width:32px}.typer-wpm{font-size:15px;font-weight:900;color:var(--color-text);background:#fff;padding:5px 12px;border-radius:var(--radius-pill);min-width:72px;text-align:center;flex-shrink:0;box-shadow:0 2px 8px #00000026;transition:opacity .3s}.typer-wpm:empty{opacity:0}.typer-body{flex:1;overflow-y:auto;padding:20px 24px 16px;display:flex;flex-direction:column;gap:14px}.typer-para-label{font-size:13px;font-weight:800;color:var(--color-text-soft);text-transform:uppercase;letter-spacing:1px}.typer-text{background:#fff;border-radius:var(--radius-xl);padding:28px 32px;box-shadow:0 4px 24px #643cb41a,0 1px 4px #0000000f;font-size:clamp(22px,2.8vw,28px);font-weight:600;line-height:2.15;display:block;word-break:normal;overflow-wrap:normal;border:1.5px solid #EDE8F8}.typer-text .char-space{font-size:inherit;opacity:1;margin:0}.typer-text .char-space.fact-char-done,.typer-text .char-space.fact-char-pending{opacity:1}.typer-finger-hint{font-size:17px;font-weight:800;color:var(--color-text-soft);text-align:center}.typer-progress-bar{height:10px;background:#e8e0f0;border-radius:var(--radius-pill);overflow:hidden;flex-shrink:0}.typer-progress-fill{height:100%;background:var(--grad-correct);border-radius:var(--radius-pill);transition:width .2s ease-out}.para-complete-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#fff9f0f7;display:flex;align-items:center;justify-content:center;z-index:10;animation:bounceIn .4s cubic-bezier(.34,1.56,.64,1)}.para-complete-card{display:flex;flex-direction:column;align-items:center;gap:16px;padding:32px 40px;text-align:center}.para-complete-emoji{font-size:72px;animation:floatBob 2s ease-in-out infinite}.para-complete-title{font-size:34px;font-weight:900;color:var(--color-text)}.para-complete-stats{display:flex;gap:32px}.para-stat{display:flex;flex-direction:column;align-items:center;background:#fff;padding:18px 32px;border-radius:var(--radius-xl);box-shadow:var(--shadow-card);min-width:110px}.para-stat-value{font-size:52px;font-weight:900;color:var(--color-text);line-height:1;letter-spacing:-2px}.para-stat-label{font-size:13px;font-weight:700;color:var(--color-text-soft);text-transform:uppercase;letter-spacing:1px;margin-top:6px}.para-complete-stars{display:flex;gap:6px}.para-complete-buttons{display:flex;gap:12px;flex-wrap:wrap;justify-content:center}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-lavender);border-radius:3px}
