*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{width:100%;height:100%;overflow:hidden}body{color:#2c3e50;-webkit-font-smoothing:antialiased;background:#87ceeb;font-family:Segoe UI,Apple SD Gothic Neo,Malgun Gothic,sans-serif}.app{width:100%;max-width:600px;height:100%;padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom);margin:0 auto;position:relative}.sky-bg{z-index:0;background:linear-gradient(#6ec6ff 0%,#b3e5fc 50%,#e1f5fe 100%);position:absolute;inset:0}.screen{z-index:1;flex-direction:column;justify-content:center;align-items:center;width:100%;height:100%;padding:24px;display:flex;position:relative;overflow-y:auto}.title{color:#fff;text-shadow:0 2px 8px #0050a04d;z-index:1;margin-bottom:12px;font-size:2.4rem;font-weight:800}.subtitle{color:#fff;text-align:center;z-index:1;text-shadow:0 1px 4px #0050a033;margin-bottom:24px;font-size:1.1rem;line-height:1.6}.start-meta{color:#ffffffd9;z-index:1;margin-top:16px;font-size:.95rem}.speed-toggle{cursor:pointer;z-index:1;text-align:left;color:#fff;background:#ffffff40;border:3px solid #fff9;border-radius:16px;align-items:center;gap:12px;width:100%;max-width:300px;padding:14px 16px;transition:background .2s,border-color .2s;display:flex}.option-toggles{z-index:1;flex-direction:column;gap:10px;width:100%;max-width:300px;margin-bottom:20px;display:flex}.tts-toggle.on{border-color:#81c784}.speed-toggle.on{color:#2c3e50;background:#ffffffeb;border-color:#ffd54f}.speed-toggle-icon{font-size:2rem;line-height:1}.speed-toggle-text{flex-direction:column;flex:1;gap:2px;display:flex}.speed-toggle-text strong{font-size:1.05rem}.speed-toggle-text small{opacity:.85;font-size:.8rem}.speed-toggle-switch{background:#00000026;border-radius:12px;padding:6px 12px;font-size:.9rem;font-weight:800}.speed-toggle.on .speed-toggle-switch{color:#5d4037;background:#ffd54f}.tts-toggle.on .speed-toggle-switch{color:#1b5e20;background:#81c784}.btn-group{z-index:1;flex-direction:column;gap:12px;width:100%;max-width:300px;display:flex}.btn{cursor:pointer;text-align:center;border:none;border-radius:16px;padding:14px 24px;font-size:1.1rem;font-weight:700;transition:transform .15s,box-shadow .15s}.btn:active{transform:scale(.96)}.btn-primary{color:#fff;background:#ff6b9d;box-shadow:0 4px 12px #ff6b9d66}.btn-secondary{color:#5d4037;background:#ffd54f;box-shadow:0 4px 12px #ffd54f66}.btn-outline{color:#1565c0;background:#ffffffd9;box-shadow:0 2px 8px #0000001a}.btn-typing{color:#1b5e20;background:#81c784;flex-direction:column;align-items:center;gap:4px;line-height:1.3;display:flex;box-shadow:0 4px 12px #81c78480}.btn-sub{opacity:.9;font-size:.8rem;font-weight:600}.photo-screen h2{color:#fff;text-shadow:0 2px 6px #0050a04d;z-index:1;font-size:1.8rem}.photo-preview{z-index:1;justify-content:center;align-items:center;width:200px;height:200px;margin:20px 0;display:flex}.cloud-preview,.falling-preview{flex-direction:column;align-items:center;gap:8px;display:flex;position:relative}.falling-emoji-preview{font-size:3rem;animation:2s ease-in-out infinite wobble}.typing-preview{transform:scale(1.15)}.falling-face-preview{object-fit:cover;border:3px solid #fff;border-radius:50%;width:56px;height:56px;box-shadow:0 4px 12px #00000026}.camera-video{object-fit:cover;border:4px solid #fff;border-radius:50%;width:200px;height:200px;box-shadow:0 4px 16px #00000026}.falling-item{z-index:5;pointer-events:none;flex-direction:column;align-items:center;gap:4px;animation:2.5s ease-in-out infinite fallWobble;display:flex;position:absolute;transform:translate(-50%)}@keyframes fallWobble{0%,to{transform:translate(-50%)rotate(-1deg)}50%{transform:translate(-50%)rotate(1deg)}}.tts-tappable{pointer-events:auto;cursor:pointer;touch-action:manipulation}.falling-emoji{filter:drop-shadow(0 3px 6px #0003);font-size:3rem;line-height:1}.falling-item--typing{animation:2.5s ease-in-out infinite wobble}.typing-card{background:#fffffff5;border-radius:18px;flex-direction:column;align-items:center;gap:6px;min-width:80px;padding:10px 16px 12px;display:flex;box-shadow:0 4px 16px #0050a02e}.falling-item--typing .falling-emoji{font-size:3.2rem}.falling-item--typing .falling-word{text-align:center;word-break:break-word;white-space:normal;max-width:140px;font-size:1rem;line-height:1.25}.falling-word{color:#1565c0;letter-spacing:.5px;white-space:nowrap;background:#fffffff2;border-radius:12px;padding:4px 12px;font-size:1rem;font-weight:800;box-shadow:0 2px 8px #0000001f}.falling-face{object-fit:cover;border:2px solid #fff;border-radius:50%;width:40px;height:40px;box-shadow:0 2px 8px #00000026}.falling-item.popping{animation:.3s ease-out forwards pop}.word-manager{background:linear-gradient(#6ec6ff,#b3e5fc)}.word-manager h2{color:#fff;text-shadow:0 2px 6px #0050a04d;font-size:1.6rem}.word-input-row{gap:8px;width:100%;max-width:400px;margin:16px 0;display:flex}.word-add-input{border:3px solid #fff;border-radius:12px;outline:none;flex:1;padding:12px 16px;font-size:1rem}.error-text{color:#d32f2f;background:#ffffffe6;border-radius:8px;margin-bottom:8px;padding:8px 16px}.emoji-picker{background:#ffffffeb;border-radius:16px;width:100%;max-width:400px;margin-bottom:16px;padding:16px}.emoji-picker p{margin-bottom:8px;font-weight:600}.emoji-grid{flex-wrap:wrap;gap:8px;display:flex}.emoji-pick-btn{cursor:pointer;background:#fff;border:2px solid #e0e0e0;border-radius:12px;width:56px;height:56px;font-size:2rem;transition:transform .15s,border-color .15s}.emoji-pick-btn:hover{border-color:#ff6b9d;transform:scale(1.1)}.word-list{background:#ffffffeb;border-radius:16px;width:100%;max-width:400px;max-height:200px;margin-bottom:16px;padding:16px;overflow-y:auto}.word-list h3{margin-bottom:8px}.word-list ul{list-style:none}.word-list-item{border-bottom:1px solid #eee;justify-content:space-between;align-items:center;padding:6px 0;font-size:1.1rem;display:flex}.btn-remove{color:#e53935;cursor:pointer;background:0 0;border:none;padding:4px 8px;font-size:1.2rem}.empty-list{color:#999;font-style:italic}.phrase-presets{background:#ffffffeb;border-radius:16px;width:100%;max-width:400px;margin-bottom:12px;padding:12px}.presets-label{margin-bottom:8px;font-size:.9rem;font-weight:700}.presets-grid{flex-wrap:wrap;gap:8px;display:flex}.preset-btn{cursor:pointer;touch-action:manipulation;background:#fff;border:2px solid #e0e0e0;border-radius:12px;padding:8px 12px;font-size:.85rem}.preset-btn:active{background:#f1f8e9;border-color:#81c784}.game-screen{background:#87ceeb;flex-direction:column;width:100%;height:100%;display:flex;position:relative}.hud{z-index:10;background:#ffffffe6;justify-content:space-between;align-items:center;padding:10px 16px;display:flex;box-shadow:0 2px 8px #0000001a}.hud-hearts{gap:2px;display:flex}.heart{font-size:1.3rem}.hud-info{flex-wrap:wrap;justify-content:flex-end;gap:12px;font-size:.95rem;font-weight:700;display:flex}.hud-easy{color:#f57c00;font-size:.85rem}.hud-typing{color:#2e7d32;font-size:.85rem}.game-area{flex:1;position:relative;overflow:hidden}.top-clouds{z-index:8;pointer-events:none;height:88px;position:absolute;top:0;left:0;right:0}.top-cloud{flex-direction:column;align-items:center;display:flex;position:absolute;top:8px;transform:translate(-50%)}.top-cloud-left{left:22%}.top-cloud-center{left:50%}.top-cloud-right{left:78%}.top-cloud-shape{background:#fff;border-radius:44px;justify-content:center;align-items:center;width:88px;height:48px;display:flex;position:relative;overflow:hidden;box-shadow:-24px 6px 0 -4px #fff,24px 6px 0 -4px #fff,0 -18px 0 -6px #fff,0 4px 14px #0050a026}.top-cloud-shape-main{border-radius:50px;width:104px;height:56px;box-shadow:-28px 8px 0 -5px #fff,28px 8px 0 -5px #fff,0 -22px 0 -8px #fff,0 6px 18px #0050a02e}.top-cloud-face{object-fit:cover;z-index:1;border-radius:50%;width:36px;height:36px}.top-cloud:after{content:"";background:linear-gradient(#ffffffb3 0%,#fff0 100%);border-radius:2px;width:2px;height:28px;margin-top:-2px;animation:1.8s ease-in-out infinite cloudDrip;display:block}.top-cloud-left:after{animation-delay:0s}.top-cloud-center:after{animation-delay:.6s}.top-cloud-right:after{animation-delay:1.2s}@keyframes cloudDrip{0%,to{opacity:.3;transform:scaleY(.6)}50%{opacity:.8;transform:scaleY(1)}}.game-sky{position:absolute;inset:0}@keyframes wobble{0%,to{transform:translate(-50%)rotate(-2deg)}50%{transform:translate(-50%)rotate(2deg)}}@keyframes pop{0%{opacity:1;transform:translate(-50%)scale(1)}50%{opacity:.8;transform:translate(-50%)scale(1.4)}to{opacity:0;transform:translate(-50%)scale(0)}}.hint-bubble{z-index:15;pointer-events:none;background:#fff;border-radius:20px;padding:10px 20px;animation:.25s hintPop;position:absolute;transform:translate(-50%);box-shadow:0 4px 16px #0003}.hint-bubble-text{letter-spacing:1px;color:#1565c0;white-space:nowrap;font-family:Menlo,Consolas,monospace;font-size:1.4rem;font-weight:800}.hint-bubble:after{content:"";border-bottom:8px solid #fff;border-left:8px solid #0000;border-right:8px solid #0000;position:absolute;top:-8px;left:50%;transform:translate(-50%)}@keyframes hintPop{0%{opacity:0;transform:translate(-50%)translateY(8px)scale(.9)}to{opacity:1;transform:translate(-50%)translateY(0)scale(1)}}.input-area{z-index:10;background:#fffffff2;align-items:center;gap:8px;padding:12px 16px;display:flex}.btn-speak{cursor:pointer;touch-action:manipulation;background:#e3f2fd;border:none;border-radius:14px;flex-shrink:0;width:48px;height:48px;font-size:1.4rem;box-shadow:0 2px 8px #0000001a}.btn-speak:active{transform:scale(.95)}.tts-hint{text-align:center;color:#ffffffe6;background:#1565c059;margin:0;padding:4px 12px;font-size:.75rem}.word-input{text-align:center;border:3px solid #64b5f6;border-radius:14px;outline:none;flex:1;padding:14px 18px;font-size:1.2rem;font-weight:600}.word-input:focus{border-color:#ff6b9d;box-shadow:0 0 0 3px #ff6b9d40}.btn-quit{cursor:pointer;z-index:20;background:#fffc;border:none;border-radius:50%;width:36px;height:36px;font-size:1rem;position:absolute;top:12px;right:12px;box-shadow:0 2px 6px #00000026}.end-screen{background:linear-gradient(#6ec6ff,#b3e5fc)}.end-screen h1{color:#fff;text-shadow:0 2px 8px #0050a04d;margin-bottom:12px;font-size:2.2rem}.score-display{color:#fff;margin-bottom:8px;font-size:1.5rem;font-weight:800}.win h1{animation:.6s bounce}@keyframes bounce{0%,to{transform:scale(1)}50%{transform:scale(1.15)}}
