.tongue-drum{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.tongue-drum__toggle{position:absolute;top:20px;left:20px;background:#ffffff1a;border:1px solid rgba(255,255,255,.3);color:#fff;padding:8px 12px;border-radius:8px;cursor:pointer;font-size:.8rem;z-index:10}.tongue-drum__svg{max-width:90vh;max-height:90vw;width:100%;height:auto;filter:drop-shadow(0 20px 40px rgba(0,0,0,.6))}.tongue-drum__pad{cursor:pointer}.tongue-drum__pad-path{transition:fill .1s}.tongue-drum__pad-label{text-shadow:0px 2px 4px rgba(0,0,0,.5);pointer-events:none;font-weight:700;fill:#fff}.free-play{width:100%;height:100%;background:radial-gradient(circle at center,#f6bf50,#ef8af2cf);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px;position:relative}.free-play__header{text-align:center;margin-bottom:20px;z-index:1;cursor:help;height:140px;display:flex;flex-direction:column;align-items:center;justify-content:center}.free-play__title{color:#fff;margin:0;font-size:3rem;letter-spacing:-1px;text-shadow:0 4px 10px rgba(0,0,0,.1)}.free-play__subtitle{color:#ffdd47;margin:0 0 10px;font-weight:600;font-size:1.4rem;transition:all .3s cubic-bezier(.4,0,.2,1);transform:scale(1);text-shadow:none}.free-play__subtitle--hover{transform:scale(1.1);text-shadow:0 0 15px rgba(255,221,71,.8)}.free-play__hint{height:30px;display:flex;align-items:center;justify-content:center;width:100%}.free-play__hint-text{color:#fffffff2;margin:0;font-size:1rem;font-weight:400;white-space:nowrap;animation:fadeIn .3s ease-in-out}.free-play__hint-line{width:100%;max-width:300px;height:2px;background:#ffffff80;border-radius:2px}.free-play__drum{width:100%;max-width:650px;flex:1 1 auto;display:flex;align-items:center;justify-content:center;min-height:300px}.free-play__footer{position:absolute;bottom:10px;left:50%;transform:translate(-50%);color:#fffc;font-weight:600;font-size:.8rem;pointer-events:none}.leaderboard{margin-top:20px;padding-bottom:20px}.leaderboard__title{color:#334155;border-bottom:2px solid #e2e8f0;padding-bottom:10px;margin-bottom:15px;font-size:1.2rem}.leaderboard__text{color:#64748b}.leaderboard__text--italic{font-style:italic}.leaderboard__table{width:100%;border-collapse:collapse;font-size:.9rem}.leaderboard__head-row{color:#64748b;text-align:left}.leaderboard__head-cell{padding:8px 4px;font-weight:600}.leaderboard__head-cell--right{text-align:right}.leaderboard__row{border-bottom:1px solid #f1f5f9}.leaderboard__rank{padding:8px 4px;color:#64748b;font-weight:400}.leaderboard__rank--top{color:#d97706;font-weight:700}.leaderboard__user{padding:8px 4px;color:#334155;font-weight:600}.leaderboard__song{padding:8px 4px;color:#64748b}.leaderboard__score{padding:8px 4px;text-align:right;color:#ed8e0a;font-weight:700}.game-sidebar{--text-main: #334155;--text-sub: #64748b;--input-bg: #f8fafc;--button-bg: #f59e0b;width:0;min-width:0;background:#fffffff2;border-left:1px solid rgba(0,0,0,.1);height:100%;overflow:hidden;display:flex;flex-direction:column;transition:all .4s cubic-bezier(.16,1,.3,1);position:relative;z-index:20;box-shadow:none}.game-sidebar--open{width:400px;min-width:400px;box-shadow:-10px 0 30px #0000001a}.game-sidebar__inner{width:400px;padding:30px;height:100%;box-sizing:border-box;opacity:0;transition:opacity .3s ease;overflow-y:auto}.game-sidebar__inner--open{opacity:1}.game-sidebar__header{display:flex;justify-content:space-between;align-items:flex-start}.game-sidebar__header-info{margin-bottom:20px;cursor:help;min-height:80px;display:flex;flex-direction:column;justify-content:center;flex:1}.game-sidebar__title{margin:0 0 10px;color:var(--text-main);font-size:1.8rem;transition:all .2s cubic-bezier(.4,0,.2,1);transform:scale(1);text-shadow:none}.game-sidebar__title--hover{transform:scale(1.02);text-shadow:0 4px 10px rgba(51,65,85,.2)}.game-sidebar__hint{height:40px;display:flex;align-items:center}.game-sidebar__hint-text{color:var(--text-sub);font-size:.95rem;line-height:1.4;margin:0;font-weight:400;animation:fadeIn .3s ease}.game-sidebar__hint-line{width:100%;height:2px;background:#e2e8f0}.game-sidebar__close{background:none;border:none;cursor:pointer;font-size:1.5rem;color:#94a3b8;padding:5px}.game-sidebar__section{margin-top:10px}.game-sidebar__label{display:block;margin-bottom:5px;font-weight:700;color:var(--text-main)}.game-sidebar__input,.game-sidebar__select{width:100%;padding:10px 15px;border-radius:10px;border:1px solid #e2e8f0;background:var(--input-bg);color:#0f172a;margin-bottom:15px;font-size:1rem;outline:none;box-sizing:border-box}.game-sidebar__select{cursor:pointer}.game-sidebar__button{width:100%;padding:15px;background:var(--button-bg);color:#fff;border:none;border-radius:10px;cursor:pointer;font-size:1.1rem;font-weight:700;margin-top:5px;box-shadow:0 4px 10px #f59e0b66;transition:background-color .2s;box-sizing:border-box}.game-sidebar__button--disabled{background:#cbd5e1;cursor:default;box-shadow:none}.game-sidebar__leaderboard{margin-top:30px;padding-top:20px;border-top:1px solid #e2e8f0}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.home{display:flex;height:100%;width:100%;position:relative;overflow:hidden}.home__panel{flex:1;position:relative;height:100%}.home__menu-button{position:absolute;top:30px;right:30px;z-index:100;background:transparent;border:none;cursor:pointer;font-size:2.2rem;color:#fbfdff;padding:0;line-height:1}.game{position:relative;width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;background:radial-gradient(circle at center,#f6bf50,#ef8af2cf)}.game__hud{position:absolute;top:20px;left:20px;right:20px;height:50px;display:flex;align-items:center;justify-content:space-between;z-index:50;pointer-events:none}.game__hud-section{pointer-events:auto}.game__toggle{background:#fff3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:1px solid rgba(255,255,255,.4);color:#fff;padding:10px 16px;border-radius:12px;cursor:pointer;font-weight:700;font-size:.9rem;box-shadow:0 4px 6px #0000001a}.game__stats{position:absolute;left:50%;transform:translate(-50%);background:#fff;padding:10px 25px;border-radius:30px;box-shadow:0 4px 15px #00000026;display:flex;align-items:center;gap:20px;pointer-events:auto;min-width:200px;justify-content:center}.game__stat{display:flex;align-items:center;gap:8px;color:#334155;font-weight:800;font-size:1.2rem}.game__stat--danger{color:#ef4444}.game__stat-icon{font-size:1.2rem}.game__stat-icon--danger{font-size:1.1rem}.game__quit{background:#ef4444;color:#fff;border:none;padding:10px 20px;border-radius:12px;font-weight:700;font-size:.9rem;cursor:pointer;box-shadow:0 4px 6px #dc26264d}.game__overlay{position:absolute;inset:0;background:#0009;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);z-index:100;display:flex;flex-direction:column;align-items:center;justify-content:center}.game__overlay-title{font-size:3rem;color:#fff;text-shadow:0 2px 10px rgba(0,0,0,.3);margin-bottom:10px}.game__overlay-subtitle{color:#fff;font-size:1.5rem;font-style:italic;margin:0 0 30px;max-width:600px}.game__play{padding:20px 60px;font-size:2rem;border-radius:50px;border:none;background:#f59e0b;color:#fff;font-weight:800;cursor:pointer;box-shadow:0 10px 20px #f59e0b66;transition:transform .2s}.game__play:hover{transform:scale(1.05)}.game__bubbles{position:absolute;top:100px;width:100%;display:flex;justify-content:center;gap:15px;z-index:10;opacity:1;transition:opacity .2s}.game__bubbles--dim{opacity:.3}.game__bubble{width:45px;height:45px;border-radius:50%;background:#fff9;border:4px solid white;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.9rem;color:#334155;box-shadow:0 8px 20px #00000026;transform:scale(1);transition:all .2s}.game__bubble--active{width:65px;height:65px;background:#facc15;font-size:1.4rem;transform:scale(1.1)}.game__drum{width:100%;max-width:700px;margin-top:80px;z-index:5}.result__overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:100}.result__modal{background:#fffffff2;border:4px solid white;border-radius:30px;padding:40px;text-align:center;max-width:450px;width:90%;box-shadow:0 20px 50px #0003;position:relative}.result__close{position:absolute;top:20px;right:20px;background:#e2e8f0;border:none;color:#64748b;font-size:1rem;font-weight:700;cursor:pointer;width:35px;height:35px;border-radius:50%;display:flex;align-items:center;justify-content:center}.result__title{font-size:2rem;color:#334155;margin:0 0 5px;font-weight:800}.result__subtitle{color:#64748b;margin-bottom:20px;font-size:1.1rem}.result__stats{background:#f8fafc;padding:20px;border-radius:20px;margin-bottom:30px;border:2px solid #e2e8f0}.result__score{font-size:3.5rem;font-weight:900;color:#facc15;margin:10px 0;text-shadow:0 2px 0 rgba(0,0,0,.1)}.result__stat-row{display:flex;justify-content:center;gap:30px;margin-top:15px;color:#475569;font-weight:700;font-size:.9rem}.result__stat-value{font-size:1.4rem}.result__stat-value--mistakes{color:#ef4444}.result__stat-value--rank{color:#7c3aed}.result__divider{border-left:2px solid #e2e8f0}.result__button-group{display:flex;justify-content:center;gap:15px}.result__button{padding:15px 30px;border-radius:12px;border:none;background:#facc15;color:#0f172a;font-size:1rem;cursor:pointer;font-weight:700;flex:1;box-shadow:0 4px 10px #facc1566}.app{height:100%;width:100%}:root{font-family:Nunito,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400}*,*:before,*:after{box-sizing:border-box}html,body,#root{margin:0;padding:0;width:100%;height:100%;overflow:hidden;background-color:#0f172a;background-repeat:no-repeat;background-attachment:fixed}@keyframes fadeIn{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}
