*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}:root{--brown: #6f4e37;--cream: #f5f0e8;--latte: #c8a882;--espresso: #3b2314;--foam: #fefcf8;--accent: #e8623a}html,body,#root{height:100%;width:100%;overflow:hidden}body{font-family:Segoe UI,system-ui,sans-serif;background:var(--cream);color:var(--espresso)}button{cursor:pointer;border:none;font-family:inherit}.home{display:flex;flex-direction:column;justify-content:center;height:100%;padding:0 20px;gap:32px;background:linear-gradient(160deg,#f5f0e8,#ede4d4)}.home-header{text-align:center}.home-logo{font-size:64px;margin-bottom:8px}.home-header h1{font-size:32px;font-weight:800;color:#3b2314;letter-spacing:-1px}.home-header p{font-size:15px;color:#9a7558;margin-top:4px}.home-games{display:flex;flex-direction:column;gap:14px;max-width:420px;width:100%;margin:0 auto}.game-card{display:flex;align-items:center;gap:16px;background:#fefcf8;border-radius:20px;padding:20px;box-shadow:0 2px 16px #6f4e371a;transition:transform .12s,box-shadow .12s;text-align:left;border:1.5px solid rgba(200,168,130,.3)}.game-card:active{transform:scale(.97);box-shadow:0 1px 6px #6f4e3714}.game-emoji{font-size:36px;flex-shrink:0}.game-label{font-size:18px;font-weight:700;color:#3b2314}.game-desc{font-size:13px;color:#9a7558;margin-top:2px}.game-arrow{margin-left:auto;font-size:24px;color:#c8a882;font-weight:300}.finger-root{display:flex;flex-direction:column;height:100%;background:#1a1a2e}.finger-header{display:flex;align-items:center;gap:12px;padding:16px 20px;color:#fff;font-size:18px;font-weight:700;background:#16213e}.back-btn{background:none;color:#fff;font-size:28px;line-height:1;padding:0 4px}.finger-arena{flex:1;position:relative;touch-action:none;overflow:hidden}.finger-hint{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#ffffffb3;gap:8px;pointer-events:none}.hint-icon{font-size:56px;animation:float 2s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.finger-hint p{font-size:18px;font-weight:600}.hint-sub{font-size:14px!important;font-weight:400!important;color:#fff6!important}.touch-char{position:absolute;font-size:120px;line-height:1;transform:translate(-50%,-50%);transition:opacity .3s,transform .3s;animation:pop-in .15s ease-out;pointer-events:none;-webkit-user-select:none;user-select:none}@keyframes pop-in{0%{transform:translate(-50%,-50%) scale(.4);opacity:0}to{transform:translate(-50%,-50%) scale(1);opacity:1}}.touch-char.eliminated{opacity:.15;transform:translate(-50%,-50%) scale(.5)}.touch-char.winner-char{font-size:144px;animation:winner-pulse .6s ease-in-out infinite alternate;filter:drop-shadow(0 0 16px rgba(255,255,255,.8))}@keyframes winner-pulse{0%{filter:drop-shadow(0 0 8px rgba(255,255,255,.5));transform:translate(-50%,-50%) scale(1)}to{filter:drop-shadow(0 0 24px rgba(255,255,255,.9));transform:translate(-50%,-50%) scale(1.15)}}.countdown-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;pointer-events:none}.countdown-number{font-size:140px;font-weight:900;color:#ffffff26;animation:countdown-pop .3s ease-out}@keyframes countdown-pop{0%{transform:scale(1.4);opacity:0}to{transform:scale(1);opacity:1}}.result-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;pointer-events:none}.result-coffeeicon{font-size:72px;animation:bounce .5s ease}@keyframes bounce{0%{transform:scale(0)}60%{transform:scale(1.2)}to{transform:scale(1)}}.result-text{font-size:32px;font-weight:900;color:#fff}.retry-btn{pointer-events:all;margin-top:8px;background:#e8623a;color:#fff;font-size:16px;font-weight:700;padding:12px 32px;border-radius:50px}.ladder-root{display:flex;flex-direction:column;height:100%;background:#fefcf8}.ladder-header{display:flex;align-items:center;gap:12px;padding:16px 20px;background:#6f4e37;color:#fff;font-size:18px;font-weight:700}.ladder-setup{flex:1;padding:24px 20px;display:flex;flex-direction:column;justify-content:center;gap:16px;max-width:420px;width:100%;margin:0 auto;overflow-y:auto}.ladder-player-card{position:relative;background:#f0ebe1;border-radius:18px;padding:14px 16px;width:100%}.char-btn.selected{border-color:#6f4e37;background:#fff8f3}.start-btn{width:100%;background:#6f4e37;color:#fff;border-radius:18px;padding:18px;font-size:18px;font-weight:700;margin-top:4px}.ladder-play{flex:1;position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:16px;gap:16px;overflow:hidden}.ladder-canvas{width:100%;max-width:380px;height:auto;border-radius:16px;background:#1a1a2e}.reveal-btn{background:#e8623a;color:#fff;border-radius:50px;padding:14px 40px;font-size:17px;font-weight:700}.reveal-btn:disabled{opacity:.6}.ladder-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0a0814d1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;text-align:center;animation:overlay-in .3s ease}.ladder-start-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;pointer-events:none;animation:start-fade 2s ease forwards}.ladder-start-text{font-size:28px;font-weight:900;color:#fff;text-shadow:0 2px 16px rgba(0,0,0,.6);letter-spacing:-.5px}@keyframes start-fade{0%{opacity:0;transform:scale(.85)}35%{opacity:1;transform:scale(1)}70%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(1.05)}}.ladder-verdict{position:relative;display:inline-block}.race-root{display:flex;flex-direction:column;height:100%;background:#fefcf8}.race-header{display:flex;align-items:center;gap:12px;padding:16px 20px;background:#1a1a2e;color:#fff;font-size:18px;font-weight:700}.race-setup{flex:1;padding:24px 20px;display:flex;flex-direction:column;justify-content:center;gap:16px;max-width:420px;width:100%;margin:0 auto;overflow-y:auto}.setup-hint{color:#9a7558;font-size:14px;text-align:center}.player-list{display:flex;flex-direction:column;gap:12px}.race-player-card{position:relative;background:#f0ebe1;border-radius:18px;padding:14px 16px;width:100%}.remove-btn{position:absolute;top:-9px;right:-9px;background:#c8a882;color:#fff;font-size:12px;width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;padding:0;line-height:1}.char-picker{display:flex;gap:5px;width:100%}.char-btn{flex:1;background:#fefcf8;border-radius:12px;padding:5px 0;font-size:22px;border:2.5px solid transparent;transition:border-color .1s;text-align:center}.char-btn.selected{border-color:#e8623a;background:#fff3ee}.char-btn.taken{opacity:.25;cursor:not-allowed}.add-btn{width:100%;background:none;border:2px dashed #c8a882;color:#9a7558;border-radius:16px;padding:14px;font-size:16px;font-weight:600}.start-btn{width:100%;background:#1a1a2e;color:#fff;border-radius:18px;padding:18px;font-size:18px;font-weight:700;margin-top:4px}.race-play{flex:1;position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:16px;gap:20px;overflow:hidden}.race-canvas{width:100%;max-width:380px;border-radius:16px;background:#1a1a2e}.race-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0a0814d1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;text-align:center;animation:overlay-in .3s ease}.race-verdict{position:relative;display:inline-block}.verdict-char{font-size:80px;display:block;animation:verdict-pop .4s ease}.verdict-badge{position:absolute;bottom:-2px;right:-16px;font-size:36px;animation:verdict-pop .3s ease .2s both}@keyframes verdict-pop{0%{transform:scale(0);opacity:0}70%{transform:scale(1.2)}to{transform:scale(1);opacity:1}}@keyframes overlay-in{0%{opacity:0}to{opacity:1}}.verdict-text{font-size:28px;font-weight:900;color:#fff;margin:4px 0 0}.verdict-sub{font-size:13px;color:#fff6;margin-top:16px}.app{width:100%;height:100%;display:flex;flex-direction:column;overflow:hidden}
