: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:stretch;width:min(300px,88vw)}.title-buttons .btn{font-size:22px;padding:18px 32px;justify-content: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}.login-screen{background:var(--grad-title);justify-content:center;align-items:center}.login-card{background:#ffffffeb;border-radius:var(--radius-xl);padding:40px 36px 32px;display:flex;flex-direction:column;align-items:center;gap:14px;width:100%;max-width:380px;box-shadow:0 12px 40px #643cb433;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.login-emoji{font-size:56px;line-height:1;animation:floatBob 3s ease-in-out infinite}.login-title{font-size:36px;font-weight:900;color:var(--color-text);letter-spacing:-.5px}.login-sub{font-size:15px;font-weight:600;color:var(--color-text-soft);text-align:center}.login-form{display:flex;flex-direction:column;gap:12px;width:100%}.login-input{font-family:var(--font-main);font-size:18px;font-weight:700;padding:14px 18px;border:3px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);background:#fff;outline:none;transition:border-color .15s;width:100%}.login-input:focus{border-color:var(--color-lavender)}.login-error{font-size:14px;font-weight:700;color:var(--color-wrong);text-align:center}.login-btn{width:100%;justify-content:center;margin-top:4px}.login-btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important;box-shadow:none!important}.login-hint{font-size:13px;font-weight:600;color:var(--color-text-soft);text-align:center;line-height:1.5;max-width:280px}.title-footer{display:flex;align-items:center;gap:12px;position:relative;z-index:1}.title-user{font-size:15px;font-weight:700;color:#ffffffd9}.title-logout{color:#ffffffb3;font-size:13px}.title-logout:hover{background:#ffffff26;color:#fff}.title-logout-btn{font-family:var(--font-main);font-size:14px;font-weight:700;padding:8px 18px;border-radius:var(--radius-md);border:2px solid rgba(255,255,255,.4);background:#ffffff1f;color:#ffffffe6;cursor:pointer;transition:all .12s}.title-logout-btn:hover{background:#ffffff40;border-color:#ffffffb3;color:#fff}.admin-screen{background:var(--grad-game-bg);justify-content:flex-start;align-items:center;padding:32px 16px}.admin-card{background:var(--color-card);border-radius:var(--radius-xl);padding:28px 28px 24px;width:100%;max-width:560px;box-shadow:var(--shadow-card);display:flex;flex-direction:column;gap:16px}.admin-header{display:flex;align-items:center;justify-content:space-between}.admin-title{font-size:28px;font-weight:900;color:var(--color-text)}.admin-sub{font-size:14px;font-weight:600;color:var(--color-text-soft);margin-top:-8px}.admin-error{font-size:14px;font-weight:700;color:var(--color-wrong)}.admin-success{font-size:14px;font-weight:700;color:var(--color-correct)}.admin-empty{font-size:15px;font-weight:600;color:var(--color-text-soft);padding:12px 0}.admin-user-list{display:flex;flex-direction:column;gap:10px}.admin-user-row{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--color-cream);border-radius:var(--radius-md);border:2px solid var(--color-border)}.admin-username{font-size:16px;font-weight:800;color:var(--color-text);flex:1}.admin-reset-inline{display:flex;align-items:center;gap:8px}.admin-pin-input{font-family:var(--font-main);font-size:16px;font-weight:700;padding:8px 12px;border:2px solid var(--color-border);border-radius:var(--radius-md);width:90px;outline:none;color:var(--color-text)}.admin-pin-input:focus{border-color:var(--color-lavender)}.btn-small{font-size:13px;padding:8px 16px}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-lavender);border-radius:3px}.btn-badges{background:linear-gradient(135deg,#f39c12,#e8c84a);color:#fff;box-shadow:0 6px #00000026,0 4px 20px #f39c1266;position:relative;gap:10px}.btn-badges:hover{transform:translateY(-2px);box-shadow:0 8px #0000001f,0 6px 24px #f39c128c}.badge-count-chip{background:#ffffff47;border-radius:var(--radius-pill);font-size:13px;font-weight:800;padding:2px 10px;letter-spacing:.5px}.badges-screen{background:var(--grad-game-bg);display:flex;flex-direction:column;align-items:stretch;padding:0;overflow-y:auto}.badges-header{display:flex;align-items:center;gap:12px;padding:16px 20px 12px;background:#fff;box-shadow:0 2px 12px #643cb414;position:sticky;top:0;z-index:10}.badges-title{flex:1;font-size:22px;font-weight:900;color:var(--color-text);text-align:center}.badges-count{font-size:15px;font-weight:800;color:var(--color-text-soft);background:var(--color-cream);padding:4px 14px;border-radius:var(--radius-pill);white-space:nowrap}.badges-stats-bar{display:flex;gap:20px;justify-content:center;flex-wrap:wrap;padding:12px 20px;background:linear-gradient(135deg,#fff9e6,#fff3e0);border-bottom:2px solid #fde8a0}.badges-stat{font-size:15px;font-weight:700;color:#b7791f}.badges-stat strong{color:#744210}.badges-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:14px;padding:20px 16px 40px}.badge-card{background:#fff;border-radius:var(--radius-lg);padding:16px 10px 14px;display:flex;flex-direction:column;align-items:center;gap:6px;box-shadow:var(--shadow-card);text-align:center;transition:transform .15s}.badge-card-earned{border:2.5px solid #F6D860;box-shadow:0 4px 20px #f39c122e,var(--shadow-card)}.badge-card-earned:hover{transform:translateY(-2px)}.badge-card-locked{border:2px solid var(--color-border);opacity:.52;filter:grayscale(.6)}.badge-emoji{font-size:2.6rem;line-height:1}.badge-name{font-size:12px;font-weight:800;color:var(--color-text);line-height:1.3}.badge-desc{font-size:11px;font-weight:600;color:var(--color-text-soft);line-height:1.4}.badge-unlock-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#1e0f3c8c;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.badge-unlock-card{background:#fff;border-radius:var(--radius-xl);padding:32px 28px 24px;max-width:320px;width:100%;display:flex;flex-direction:column;align-items:center;gap:8px;box-shadow:0 20px 60px #1e0f3c59;animation:bounceIn .45s cubic-bezier(.36,.07,.19,.97) both}.badge-unlock-label{font-size:13px;font-weight:800;letter-spacing:2px;text-transform:uppercase;color:#e67e22;background:linear-gradient(135deg,#f39c12,#e8c84a);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.badge-unlock-emoji{font-size:5rem;line-height:1;margin:4px 0;animation:floatBob 2s ease-in-out infinite}.badge-unlock-name{font-size:1.5rem;font-weight:900;color:var(--color-text);text-align:center}.badge-unlock-flavor{font-size:14px;font-weight:600;color:var(--color-text-soft);text-align:center;line-height:1.5;max-width:240px}.badge-unlock-dismiss{margin-top:10px;background:linear-gradient(135deg,#f39c12,#e8c84a);color:#fff;border:none;border-radius:var(--radius-pill);font-family:var(--font-main);font-size:15px;font-weight:800;padding:10px 28px;cursor:pointer;box-shadow:0 4px #0000001f;transition:transform .1s,box-shadow .1s}.badge-unlock-dismiss:hover{transform:translateY(-2px);box-shadow:0 6px #0000001a}.complete-stats-row{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}.complete-stat{display:flex;flex-direction:column;align-items:center;background:#fff;padding:14px 32px;border-radius:var(--radius-xl);box-shadow:var(--shadow-card);min-width:100px}.complete-stat-value{font-size:44px;font-weight:900;color:var(--color-text);line-height:1;letter-spacing:-1px}.complete-stat-label{font-size:13px;font-weight:700;color:var(--color-text-soft);text-transform:uppercase;letter-spacing:1px;margin-top:2px}.btn-class{background:linear-gradient(135deg,#2ecc71,#27ae60);color:#fff;box-shadow:0 6px #00000026,0 4px 20px #2ecc7166}.btn-class:hover{transform:translateY(-2px);box-shadow:0 8px #0000001f,0 6px 24px #2ecc718c}.btn-class-outline{border:2.5px dashed #2ECC71;background:#2ecc7112;color:#27ae60}.btn-class-outline:hover{background:#2ecc7126}.title-join-form{display:flex;flex-direction:column;gap:8px;align-items:stretch}.title-join-input{font-family:var(--font-main);font-size:20px;font-weight:800;letter-spacing:4px;text-align:center;padding:12px 16px;border:2.5px solid var(--color-lavender);border-radius:var(--radius-md);outline:none;color:var(--color-text);text-transform:uppercase}.title-join-input:focus{border-color:#2ecc71}.title-join-btns{display:flex;gap:8px;justify-content:center}.title-join-error{font-size:13px;font-weight:700;color:var(--color-wrong);text-align:center;margin:0}.class-screen{background:var(--grad-game-bg);display:flex;flex-direction:column;align-items:stretch;padding:0;overflow-y:auto}.class-header{display:flex;align-items:center;gap:16px;padding:14px 20px;background:#fff;box-shadow:0 2px 12px #643cb414;position:sticky;top:0;z-index:10}.class-header-title{display:flex;align-items:center;gap:10px;flex:1}.class-header-emoji{font-size:28px}.class-header-name{font-size:18px;font-weight:900;color:var(--color-text);line-height:1.1}.class-header-code{font-size:13px;font-weight:700;color:var(--color-text-soft)}.class-passages{display:flex;flex-direction:column;gap:12px;padding:20px 16px;max-width:600px;width:100%;margin:0 auto}.class-passage-card{background:var(--color-card);border-radius:var(--radius-xl);padding:18px 20px;border:2px solid var(--color-border);box-shadow:var(--shadow-card);display:flex;flex-direction:column;gap:10px;text-align:left;cursor:pointer;font-family:var(--font-main);transition:transform .12s,box-shadow .12s;width:100%}.class-passage-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #643cb41f;border-color:var(--color-lavender)}.class-passage-top{display:flex;align-items:center;justify-content:space-between;gap:12px}.class-passage-title{font-size:17px;font-weight:800;color:var(--color-text)}.class-passage-done-chip{font-size:12px;font-weight:800;background:#d4f5e9;color:#1a9a6a;padding:3px 10px;border-radius:var(--radius-pill);white-space:nowrap}.class-passage-pips{display:flex;gap:5px;flex-wrap:wrap}.class-pip{width:10px;height:10px;border-radius:50%}.class-pip-done{background:var(--color-correct)}.class-pip-pending{background:var(--color-border)}.class-passage-meta{font-size:13px;font-weight:600;color:var(--color-text-soft)}.class-empty{text-align:center;padding:48px 24px}.class-empty-emoji{font-size:48px;margin-bottom:12px}.class-empty-text{font-size:17px;font-weight:700;color:var(--color-text);margin:0 0 6px}.class-empty-sub{font-size:14px;color:var(--color-text-soft);margin:0}.teacher-screen{background:var(--grad-game-bg);justify-content:flex-start;align-items:center;padding:32px 16px;overflow-y:auto}.teacher-card{background:var(--color-card);border-radius:var(--radius-xl);padding:28px 28px 24px;width:100%;max-width:640px;box-shadow:var(--shadow-card);display:flex;flex-direction:column;gap:20px}.teacher-code-block{display:flex;align-items:center;gap:12px;background:#f3f0ff;border:2px solid var(--color-lavender);border-radius:var(--radius-lg);padding:14px 18px}.teacher-code-label{font-size:13px;font-weight:700;color:var(--color-text-soft);text-transform:uppercase;letter-spacing:1px}.teacher-code{font-size:28px;font-weight:900;color:var(--color-text);letter-spacing:5px;flex:1}.teacher-code-hint{font-size:13px;font-weight:600;color:var(--color-text-soft);margin:-12px 0 0}.teacher-section{display:flex;flex-direction:column;gap:12px;border-top:2px solid var(--color-border);padding-top:16px}.teacher-section-header{display:flex;align-items:center;justify-content:space-between}.teacher-section-title{font-size:17px;font-weight:900;color:var(--color-text);margin:0}.teacher-empty{font-size:14px;font-weight:600;color:var(--color-text-soft);margin:0}.teacher-passage-row{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--color-cream);border-radius:var(--radius-md);border:2px solid var(--color-border)}.teacher-passage-title{flex:1;font-size:15px;font-weight:700;color:var(--color-text)}.teacher-passage-paras{font-size:13px;font-weight:600;color:var(--color-text-soft)}.teacher-input{font-family:var(--font-main);font-size:15px;font-weight:700;padding:10px 14px;border:2px solid var(--color-border);border-radius:var(--radius-md);outline:none;color:var(--color-text);width:100%;box-sizing:border-box}.teacher-input:focus{border-color:var(--color-lavender)}.teacher-textarea{font-family:var(--font-main);font-size:14px;font-weight:600;padding:10px 14px;border:2px solid var(--color-border);border-radius:var(--radius-md);outline:none;color:var(--color-text);width:100%;resize:vertical;box-sizing:border-box;line-height:1.5}.teacher-textarea:focus{border-color:var(--color-lavender)}.teacher-add-form{display:flex;flex-direction:column;gap:10px;background:var(--color-cream);border:2px solid var(--color-lavender);border-radius:var(--radius-lg);padding:16px}.teacher-preview{background:#fff;border:2px solid var(--color-border);border-radius:var(--radius-md);padding:12px 14px;display:flex;flex-direction:column;gap:8px;max-height:200px;overflow-y:auto}.teacher-preview-label{font-size:12px;font-weight:700;color:var(--color-text-soft);text-transform:uppercase;letter-spacing:.5px}.teacher-preview-para{display:flex;gap:10px;font-size:13px;color:var(--color-text);line-height:1.5}.teacher-preview-num{font-weight:800;color:var(--color-lavender);min-width:18px}.teacher-form-btns{display:flex;gap:8px}.teacher-dashboard{overflow-x:auto}.teacher-dashboard-table{display:flex;flex-direction:column;gap:2px;min-width:100%}.teacher-dash-header-row,.teacher-dash-row{display:flex;gap:2px;align-items:center}.teacher-dash-header-row{background:#f3f0ff;border-radius:var(--radius-md) var(--radius-md) 0 0}.teacher-dash-row{background:var(--color-cream)}.teacher-dash-row:last-child{border-radius:0 0 var(--radius-md) var(--radius-md)}.teacher-dash-cell{padding:8px 10px;font-size:13px;font-weight:700}.teacher-dash-name-col{flex:1;min-width:90px;color:var(--color-text)}.teacher-dash-passage-col{width:100px;text-align:center;color:var(--color-text-soft);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.teacher-dash-done{color:#1a9a6a;font-weight:800}.teacher-dash-partial{color:var(--color-ring)}.teacher-dash-none{color:#c0b8d8}.admin-section{border-top:2px solid var(--color-border);padding-top:16px;display:flex;flex-direction:column;gap:10px}.admin-section-title{font-size:15px;font-weight:900;color:var(--color-text);margin:0}.admin-create-teacher{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.admin-tabs{display:flex;gap:8px;border-bottom:2px solid var(--color-border);padding-bottom:12px}.admin-tab{font-family:var(--font-main);font-size:14px;font-weight:800;padding:8px 18px;border-radius:var(--radius-md);border:2px solid transparent;background:var(--color-cream);color:var(--color-text-soft);cursor:pointer;transition:all .12s}.admin-tab:hover{background:var(--color-border);color:var(--color-text)}.admin-tab-active{background:var(--color-text);color:#fff;border-color:var(--color-text)}.admin-badge-grid{display:flex;flex-direction:column;gap:6px;max-height:420px;overflow-y:auto}.admin-badge-row{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:8px;border:1.5px solid var(--color-border);cursor:pointer;font-size:14px;background:#fff}.admin-badge-row.admin-badge-earned{background:#f0fdf4;border-color:#86efac}.admin-badge-emoji{font-size:18px}.admin-badge-name{flex:1}.admin-field-label{display:block;font-size:13px;font-weight:700;color:var(--color-text-soft);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.admin-create-teacher-tab{display:flex;flex-direction:column;gap:4px}.btn-danger{background:var(--color-wrong);color:#fff;box-shadow:0 4px #ff475759;border:none}.btn-danger:hover{background:#e03347}.class-leave-confirm{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.class-leave-prompt{font-size:13px;font-weight:700;color:var(--color-wrong)}.teacher-dissolve-confirm{background:#fff0f0;border:2px solid #FFCDD2;border-radius:var(--radius-md);padding:12px 14px;font-size:13px;font-weight:600;color:var(--color-text)}.btn-games{background:linear-gradient(135deg,#00b894,#00cec9);color:#fff;box-shadow:0 6px #00000026,0 4px 20px #00b89466}.btn-games:hover{transform:translateY(-2px);box-shadow:0 8px #00000026,0 6px 24px #00b89480}.games-hub-screen{background:var(--grad-game-bg);padding:24px 16px 32px;gap:12px}.games-hub-sub{font-size:16px;font-weight:600;color:var(--color-text-soft);text-align:center;margin-bottom:8px}.games-hub-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px;width:100%;max-width:820px}.game-card{background:var(--color-card);border:3px solid var(--color-border);border-top:6px solid var(--game-color, var(--color-lavender));border-radius:var(--radius-lg);padding:28px 20px 22px;display:flex;flex-direction:column;align-items:center;gap:10px;cursor:pointer;font-family:var(--font-main);text-align:center;box-shadow:var(--shadow-card);transition:transform .15s cubic-bezier(.34,1.56,.64,1),box-shadow .15s ease}.game-card:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 8px 28px #643cb42e}.game-card:active{transform:translateY(0) scale(.97)}.game-card-emoji{font-size:56px;line-height:1;filter:drop-shadow(0 4px 8px rgba(100,60,180,.15))}.game-card-name{font-size:22px;font-weight:900;color:var(--color-text)}.game-card-tagline{font-size:14px;font-weight:600;color:var(--color-text-soft);line-height:1.4}.game-card-stars{font-size:14px;font-weight:800;color:var(--color-gold-2);background:#fff6e0;padding:4px 12px;border-radius:var(--radius-pill);margin-top:4px}.arcade-screen{background:var(--grad-game-bg)}.arcade-ready{flex:1;display:flex;align-items:center;justify-content:center;padding:24px}.arcade-ready-card{background:var(--color-card);border-radius:var(--radius-xl);box-shadow:var(--shadow-card);padding:36px 32px;display:flex;flex-direction:column;align-items:center;gap:14px;max-width:480px;text-align:center;animation:bounceIn .5s cubic-bezier(.34,1.56,.64,1) both}.arcade-ready-emoji{font-size:64px;line-height:1;animation:floatBob 3s ease-in-out infinite}.arcade-ready-title{font-size:32px;font-weight:900;color:var(--color-text)}.arcade-ready-level{font-size:17px;font-weight:800;color:var(--color-text-soft);background:#f0edf8;padding:6px 16px;border-radius:var(--radius-pill)}.arcade-ready-howto{font-size:16px;font-weight:600;color:var(--color-text-soft);line-height:1.5}.arcade-ready-best{font-size:15px;font-weight:700;color:var(--color-text)}.arcade-new-best{font-size:16px;font-weight:800;color:var(--color-gold-2)}.arcade-ready-buttons{display:flex;flex-direction:column;gap:10px;margin-top:8px;align-items:center}.arcade-result-score{font-size:48px;font-weight:900;color:var(--color-text);line-height:1}.arcade-result-label{font-size:18px;font-weight:700;color:var(--color-text-soft)}.arcade-result-stars{display:flex;gap:6px}.balloon-field{flex:1;position:relative;background:linear-gradient(180deg,#bde3ff,#e3f3ff 70%,#d2f2dc);border-radius:var(--radius-xl);overflow:hidden;box-shadow:inset 0 2px 12px #643cb414,var(--shadow-card);min-height:180px}.balloon{position:absolute;width:52px;height:60px;display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:900;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.3);background:radial-gradient(circle at 35% 30%,rgba(255,255,255,.55) 0%,transparent 45%),var(--balloon-color, #FF6B6B);border-radius:50%/55% 55% 45% 45%;transform:translate(-50%);pointer-events:none;box-shadow:0 4px 10px #0000001f}.balloon:after{content:"";position:absolute;bottom:-16px;left:50%;width:2px;height:16px;background:#00000040}@keyframes balloonPop{0%{transform:translate(-50%) scale(1);opacity:1}30%{transform:translate(-50%) scale(1.8);opacity:1}70%{transform:translate(-50%) scale(.9);opacity:.5}to{transform:translate(-50%) scale(.1);opacity:0}}.balloon-popping{animation:balloonPop .35s ease-out forwards;border-color:transparent!important;box-shadow:0 0 24px #ffdc50cc,0 0 48px #ff963266}.wb-field{flex:1;position:relative;background:linear-gradient(160deg,#1a1a3e,#2d2d5f);border-radius:var(--radius-xl);overflow:hidden;box-shadow:inset 0 2px 12px #0000004d,var(--shadow-card);min-height:180px}.wb-field:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(circle 1px at 15% 25%,rgba(255,255,255,.7) 50%,transparent 51%),radial-gradient(circle 1px at 45% 70%,rgba(255,255,255,.5) 50%,transparent 51%),radial-gradient(circle 1px at 70% 20%,rgba(255,255,255,.6) 50%,transparent 51%),radial-gradient(circle 1px at 85% 55%,rgba(255,255,255,.5) 50%,transparent 51%),radial-gradient(circle 1px at 30% 85%,rgba(255,255,255,.6) 50%,transparent 51%),radial-gradient(circle 1px at 60% 40%,rgba(255,255,255,.4) 50%,transparent 51%);pointer-events:none}.wb-rocket{position:absolute;left:6px;top:50%;transform:translateY(-50%) rotate(45deg);font-size:40px;filter:drop-shadow(0 0 12px rgba(255,200,80,.5));pointer-events:none}.wb-word{position:absolute;font-size:clamp(16px,2.4vw,21px);font-weight:800;letter-spacing:1px;padding:14px 20px;background:radial-gradient(circle at 35% 28%,#858585,#4d4845 45%,#2e2a28);border:3px solid #1A1715;box-shadow:inset 0 2px 5px #ffffff1f,inset 0 -2px 5px #0000004d,0 5px 14px #00000080;transform:translateY(-50%);pointer-events:none;white-space:nowrap;transition:border-color .1s,box-shadow .1s,background .1s}.wb-asteroid-0{border-radius:42% 58% 65% 35%/38% 54% 46% 62%}.wb-asteroid-1{border-radius:55% 45% 38% 62%/62% 44% 56% 38%}.wb-asteroid-2{border-radius:68% 32% 55% 45%/45% 62% 38% 55%}.wb-asteroid-3{border-radius:35% 65% 44% 56%/58% 35% 65% 42%}.wb-asteroid-4{border-radius:62% 38% 48% 52%/32% 68% 44% 56%}.wb-word-locked{background:radial-gradient(circle at 35% 28%,#b09060,#7a5830 45%,#4a3018);border-color:var(--color-gold);box-shadow:inset 0 2px 5px #ffdc5026,0 0 22px #ffd7008c,0 5px 14px #0006}.wb-typed{color:#00e5a0;text-shadow:0 0 8px rgba(0,229,160,.6)}.wb-rest{color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.4)}.wb-wave{font-size:15px;font-weight:800;color:var(--color-text);background:#f0edf8;padding:4px 12px;border-radius:var(--radius-pill)}.tt-track{width:100%;max-width:900px;margin:0 auto;display:flex;flex-direction:column;gap:8px;background:linear-gradient(180deg,#d2f2dc,#bde8cc);border-radius:var(--radius-lg);padding:14px 18px;box-shadow:var(--shadow-card)}.tt-lane{position:relative;height:38px;background:repeating-linear-gradient(90deg,#fff,#fff 24px,#f2efe8 24px,#f2efe8 48px);border-radius:var(--radius-pill);border:2px solid rgba(100,60,180,.12)}.tt-runner{position:absolute;top:50%;transform:translate(-20%,-50%) scaleX(-1);font-size:28px;line-height:1;transition:left .12s linear;z-index:1}.tt-finish{position:absolute;right:6px;top:50%;transform:translateY(-50%);font-size:22px}.tt-text{width:100%;max-width:900px;margin:0 auto;background:#fff;border-radius:var(--radius-lg);padding:18px 24px;box-shadow:0 4px 24px #643cb41a;border:1.5px solid #EDE8F8;font-size:clamp(17px,2.2vw,22px);font-weight:600;line-height:1.9;max-height:32vh;overflow-y:auto}.tt-text .char-space{font-size:inherit;opacity:1;margin:0}.arcade-custom-screen{background:var(--grad-game-bg);padding:24px 16px 32px;gap:16px}.custom-card{background:var(--color-card);border-radius:var(--radius-xl);box-shadow:var(--shadow-card);padding:28px 24px;display:flex;flex-direction:column;gap:22px;width:100%;max-width:680px;align-items:center}.custom-row{width:100%;display:flex;flex-direction:column;gap:10px}.custom-row-label{font-size:15px;font-weight:800;color:var(--color-text-soft);text-transform:uppercase;letter-spacing:.8px}.custom-row-opts{display:flex;flex-wrap:wrap;gap:8px}.custom-opt{font-family:var(--font-main);font-size:15px;font-weight:700;padding:8px 16px;border-radius:var(--radius-pill);border:2.5px solid var(--color-border);background:#f7f5ff;color:var(--color-text-soft);cursor:pointer;transition:transform .1s,border-color .1s,background .1s,color .1s;white-space:nowrap}.custom-opt:hover{border-color:var(--color-lavender);background:#f0eeff;color:var(--color-text);transform:translateY(-1px)}.custom-opt-on{background:linear-gradient(135deg,#5f27cd,#7b68ee);border-color:#5f27cd;color:#fff;box-shadow:0 3px #5f27cd40,0 2px 10px #5f27cd4d}.custom-opt-on:hover{background:linear-gradient(135deg,#5f27cd,#7b68ee);color:#fff}.level-card-custom{border-style:dashed;border-color:var(--color-lavender);background:#f7f5ff}.level-card-custom:hover{border-style:solid}.custom-game-btn{font-family:var(--font-main);font-size:16px;font-weight:800;padding:14px 28px;border-radius:var(--radius-pill);border:3px dashed var(--color-lavender);background:#f7f5ff;color:var(--color-text);cursor:pointer;width:100%;max-width:700px;transition:background .15s,border-color .15s,transform .12s;letter-spacing:.2px}.custom-game-btn:hover{background:#eeeaff;border-color:#7b68ee;border-style:solid;transform:translateY(-2px)}
