.pwa-notification[data-v-becb97af]{position:fixed;bottom:20px;left:20px;right:20px;z-index:1000;pointer-events:none}.notification-content[data-v-becb97af]{background:#000000e6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:15px;padding:20px;color:#fff;box-shadow:0 8px 32px #0000004d;border:1px solid rgba(255,255,255,.1);pointer-events:auto;max-width:500px;margin:0 auto}.update-notification[data-v-becb97af],.offline-notification[data-v-becb97af]{display:flex;align-items:center;gap:15px}.notification-icon[data-v-becb97af]{font-size:2rem;flex-shrink:0}.notification-text[data-v-becb97af]{flex:1}.notification-text h4[data-v-becb97af]{margin:0 0 5px;font-size:1.1rem;font-weight:600}.notification-text p[data-v-becb97af]{margin:0;font-size:.9rem;opacity:.8}.notification-actions[data-v-becb97af]{display:flex;gap:10px;flex-shrink:0}.btn[data-v-becb97af]{padding:8px 16px;border:none;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-primary[data-v-becb97af]{background:linear-gradient(45deg,#4ecdc4,#44a08d);color:#fff}.btn-primary[data-v-becb97af]:hover{transform:translateY(-1px);box-shadow:0 4px 12px #4ecdc466}.btn-secondary[data-v-becb97af]{background:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.2)}.btn-secondary[data-v-becb97af]:hover{background:#fff3}@media (max-width: 768px){.pwa-notification[data-v-becb97af]{left:10px;right:10px;bottom:10px}.notification-content[data-v-becb97af]{padding:15px}.update-notification[data-v-becb97af],.offline-notification[data-v-becb97af]{flex-direction:column;text-align:center;gap:10px}.notification-actions[data-v-becb97af]{justify-content:center;width:100%}.btn[data-v-becb97af]{flex:1;min-width:80px}}#app{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;width:100vw;height:100vh;margin:0;padding:0;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;align-items:center;-webkit-user-select:none;-webkit-touch-callout:none;-webkit-tap-highlight-color:transparent;touch-action:manipulation;overscroll-behavior:none}*{box-sizing:border-box;margin:0;padding:0}body{margin:0;padding:0;overflow:hidden;-webkit-text-size-adjust:100%;overscroll-behavior-y:contain}@media (max-width: 768px){#app{height:100vh;height:100dvh}}@media (pointer: coarse){button,input,select{touch-action:manipulation}}.home[data-v-7963baeb]{min-height:100vh;background:linear-gradient(135deg,#1e3c72,#2a5298);color:#fff;padding:20px}.home-container[data-v-7963baeb]{max-width:800px;margin:0 auto;padding:20px;background:#ffffff0d;border-radius:20px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}@media (max-width: 768px){.home-container[data-v-7963baeb]{padding:15px;margin:10px;border-radius:15px}}.title[data-v-7963baeb]{text-align:center;font-size:4rem;margin-bottom:10px;text-shadow:0 0 20px rgba(255,255,255,.5)}.subtitle[data-v-7963baeb]{text-align:center;font-size:1.5rem;margin-bottom:40px}.menu[data-v-7963baeb]{display:flex;flex-direction:column;gap:30px}.player-input[data-v-7963baeb]{margin-bottom:20px}.name-input[data-v-7963baeb],.game-id-input[data-v-7963baeb]{width:100%;padding:15px;border:2px solid rgba(255,255,255,.2);border-radius:10px;background:#ffffff1a;color:#fff;font-size:1.1rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}@media (max-width: 768px){.player-input[data-v-7963baeb]{margin-bottom:15px}.name-input[data-v-7963baeb],.game-id-input[data-v-7963baeb]{padding:12px;font-size:1rem}}.name-input[data-v-7963baeb]:focus,.game-id-input[data-v-7963baeb]:focus{outline:none;border-color:#4ecdc4;box-shadow:0 0 15px #4ecdc44d}.menu-buttons[data-v-7963baeb]{display:flex;gap:20px;justify-content:center;flex-wrap:wrap}@media (max-width: 768px){.menu-buttons[data-v-7963baeb]{flex-direction:column;gap:15px}}.btn[data-v-7963baeb]{padding:15px 30px;border:none;border-radius:15px;cursor:pointer;transition:all .3s ease;font-weight:700;text-transform:uppercase;letter-spacing:1px}.btn.main-action[data-v-7963baeb]{background:linear-gradient(135deg,#4ecdc4,#44a08d);color:#fff;box-shadow:0 8px 25px #4ecdc44d;min-height:80px;display:flex;align-items:center;justify-content:center;flex:1;max-width:300px}.btn-content[data-v-7963baeb]{display:flex;align-items:center;gap:15px;text-align:left}.btn-icon[data-v-7963baeb]{font-size:2rem;min-width:40px}.btn-text[data-v-7963baeb]{display:flex;flex-direction:column;gap:2px}.btn-title[data-v-7963baeb]{font-size:1.2rem;font-weight:700}.btn-subtitle[data-v-7963baeb]{font-size:.9rem;opacity:.8;font-weight:400}@media (max-width: 768px){.btn.main-action[data-v-7963baeb]{min-height:70px;max-width:none}.btn-content[data-v-7963baeb]{gap:10px}.btn-icon[data-v-7963baeb]{font-size:1.8rem;min-width:35px}.btn-title[data-v-7963baeb]{font-size:1.1rem}.btn-subtitle[data-v-7963baeb]{font-size:.85rem}}.btn[data-v-7963baeb]:disabled{opacity:.5;cursor:not-allowed}.btn-primary[data-v-7963baeb]{background:linear-gradient(135deg,#4ecdc4,#44a08d);color:#fff}.btn-primary[data-v-7963baeb]:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 12px 35px #4ecdc466}.btn-secondary[data-v-7963baeb]{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-secondary[data-v-7963baeb]:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 12px 35px #667eea66}.btn-accent[data-v-7963baeb]{background:linear-gradient(135deg,#ff6b6b,#ee5a52);color:#fff}.btn-accent[data-v-7963baeb]:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 12px 35px #ff6b6b66}.join-section[data-v-7963baeb]{background:#ffffff0d;padding:20px;border-radius:15px;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}@media (max-width: 768px){.join-section[data-v-7963baeb]{padding:15px;border-radius:10px}}.open-games[data-v-7963baeb]{margin-bottom:30px}.games-header[data-v-7963baeb]{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.games-header h3[data-v-7963baeb]{margin:0;font-size:1.3rem}.refresh-btn[data-v-7963baeb]{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;padding:8px 12px;border-radius:8px;cursor:pointer;transition:all .2s ease}.refresh-btn[data-v-7963baeb]:hover:not(:disabled){background:#fff3;transform:rotate(180deg)}.refresh-btn[data-v-7963baeb]:disabled{opacity:.5;cursor:not-allowed}.loading-games[data-v-7963baeb]{text-align:center;padding:20px;opacity:.7}.no-games[data-v-7963baeb]{text-align:center;padding:30px;opacity:.7;font-style:italic}.games-list[data-v-7963baeb]{display:flex;flex-direction:column;gap:10px;max-height:300px;overflow-y:auto}.game-item[data-v-7963baeb]{display:flex;justify-content:space-between;align-items:center;padding:15px;background:#ffffff1a;border-radius:10px;cursor:pointer;transition:all .2s ease}@media (max-width: 768px){.game-item[data-v-7963baeb]{flex-direction:column;gap:10px;text-align:center}.game-id[data-v-7963baeb]{font-size:1rem;font-weight:700}.game-players[data-v-7963baeb]{font-size:.9rem;opacity:.8}.join-button[data-v-7963baeb]{width:100%;padding:10px}}.game-item[data-v-7963baeb]:hover{background:#ffffff26;transform:translate(5px)}.game-info[data-v-7963baeb]{display:flex;flex-direction:column;gap:5px}.game-id[data-v-7963baeb]{font-weight:700;font-size:1.1rem;color:#4ecdc4}.game-players[data-v-7963baeb]{font-size:.9rem;opacity:.8}.game-status[data-v-7963baeb]{font-size:.8rem}.status-active[data-v-7963baeb]{color:#4ecdc4}.status-waiting[data-v-7963baeb]{color:#ffd93d}.join-button[data-v-7963baeb]{background:#4ecdc4;color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;font-weight:700}.manual-join[data-v-7963baeb]{text-align:center;padding-top:20px;border-top:1px solid rgba(255,255,255,.1)}.manual-join h4[data-v-7963baeb]{margin-bottom:15px;color:#fffc}.game-mode-selector[data-v-7963baeb]{text-align:center}.game-mode-selector h3[data-v-7963baeb]{margin-bottom:15px;font-size:1.3rem;color:#4ecdc4}.mode-options[data-v-7963baeb]{display:flex;gap:5px;justify-content:center;flex-wrap:no-wrap}@media (max-width: 768px){.game-mode-selector[data-v-7963baeb]{text-align:center}.mode-options[data-v-7963baeb]{flex-direction:column;gap:10px}.mode-option[data-v-7963baeb]{width:100%}}.mode-option[data-v-7963baeb]{position:relative}.mode-option input[type=radio][data-v-7963baeb]{position:absolute;opacity:0}.mode-card[data-v-7963baeb]{background:#ffffff1a;border:2px solid rgba(255,255,255,.2);border-radius:10px;padding:15px;cursor:pointer;transition:all .3s ease;min-width:200px}@media (max-width: 768px){.mode-card[data-v-7963baeb]{min-width:auto;padding:12px}.mode-card h4[data-v-7963baeb]{font-size:1rem}.mode-card p[data-v-7963baeb]{font-size:.85rem}}.mode-option input[type=radio]:checked+.mode-card[data-v-7963baeb]{border-color:#4ecdc4;background:#4ecdc433;box-shadow:0 0 15px #4ecdc44d}.mode-card h4[data-v-7963baeb]{margin:0 0 8px;font-size:1.1rem;color:#fff}.mode-card p[data-v-7963baeb]{margin:0;font-size:.9rem;opacity:.8}.mode-details[data-v-7963baeb]{font-size:.8rem!important;margin-top:8px!important;color:#4ecdc4!important;opacity:1!important}.side-selector[data-v-7963baeb]{width:100%;padding:10px;border:2px solid rgba(255,255,255,.2);border-radius:8px;background:#ffffff1a;color:#fff;font-size:1rem;margin-top:10px}.side-selector[data-v-7963baeb]:focus{outline:none;border-color:#4ecdc4}.error[data-v-7963baeb]{background:#ff6b6b33;color:#ff6b6b;padding:15px;border-radius:10px;text-align:center;border:1px solid rgba(255,107,107,.3)}@media (max-width: 600px){.home-container[data-v-7963baeb]{margin:5px;padding:15px}.title[data-v-7963baeb]{font-size:3rem}.subtitle[data-v-7963baeb]{font-size:1.2rem}}@media (max-width: 480px){.home[data-v-7963baeb]{padding:10px}.home-container[data-v-7963baeb]{padding:12px;margin:0}.title[data-v-7963baeb]{font-size:2.5rem}.subtitle[data-v-7963baeb]{font-size:1.1rem}.btn.main-action[data-v-7963baeb]{min-height:60px;padding:12px 20px}.btn-icon[data-v-7963baeb]{font-size:1.6rem}.btn-title[data-v-7963baeb]{font-size:1rem}.btn-subtitle[data-v-7963baeb]{font-size:.8rem}}.game[data-v-414ab6e3]{display:flex;flex-direction:column;height:100vh;background:linear-gradient(135deg,#1e3c72,#2a5298);color:#fff}.game-header[data-v-414ab6e3]{padding:1rem;background:#0003;border-bottom:1px solid rgba(255,255,255,.1)}.game-info[data-v-414ab6e3]{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.game-id[data-v-414ab6e3]{font-weight:700;font-size:1.1rem}.arena-info[data-v-414ab6e3]{font-size:.9rem;color:#4ecdc4}.scores[data-v-414ab6e3]{display:flex;gap:1rem;flex-wrap:wrap}.score[data-v-414ab6e3]{background:#ffffff1a;padding:.5rem 1rem;border-radius:8px;text-align:center;min-width:80px}.score.active[data-v-414ab6e3]{background:#4ecdc4;color:#000}.score .label[data-v-414ab6e3]{display:block;font-size:.8rem;margin-bottom:.25rem}.score .value[data-v-414ab6e3]{display:block;font-size:1.5rem;font-weight:700}.game-container[data-v-414ab6e3]{flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:2rem}.loading[data-v-414ab6e3],.waiting[data-v-414ab6e3],.ready[data-v-414ab6e3]{text-align:center;max-width:500px}.loading h2[data-v-414ab6e3],.waiting h2[data-v-414ab6e3],.ready h2[data-v-414ab6e3]{margin-bottom:1rem;font-size:2rem}.spinner[data-v-414ab6e3]{border:4px solid rgba(255,255,255,.3);border-radius:50%;border-top:4px solid #4ecdc4;width:40px;height:40px;animation:spin-414ab6e3 1s linear infinite;margin:0 auto 1rem}@keyframes spin-414ab6e3{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.arena-preview[data-v-414ab6e3]{margin:2rem 0}.polygon-arena[data-v-414ab6e3]{margin:0 auto;background:#0000004d;border-radius:10px;padding:1rem;display:inline-block}.paddle-label[data-v-414ab6e3]{font-size:10px;font-weight:700}.waiting-animation[data-v-414ab6e3]{display:flex;justify-content:center;gap:.5rem;margin-top:2rem}.dot[data-v-414ab6e3]{width:10px;height:10px;background:#4ecdc4;border-radius:50%;animation:bounce-414ab6e3 1.4s ease-in-out infinite both}.dot[data-v-414ab6e3]:nth-child(1){animation-delay:-.32s}.dot[data-v-414ab6e3]:nth-child(2){animation-delay:-.16s}@keyframes bounce-414ab6e3{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}.ready-info[data-v-414ab6e3]{margin:1.5rem 0}.ready-info p[data-v-414ab6e3]{margin:.5rem 0}.start-btn[data-v-414ab6e3]{background:linear-gradient(45deg,#4ecdc4,#44a08d);color:#fff;border:none;padding:1rem 2rem;border-radius:8px;font-size:1.1rem;font-weight:700;cursor:pointer;transition:transform .2s}.start-btn[data-v-414ab6e3]:hover{transform:translateY(-2px)}.game-area[data-v-414ab6e3]{display:flex;flex-direction:column;align-items:center}.game-canvas[data-v-414ab6e3]{border:2px solid #4ecdc4;border-radius:10px;background:#000}.controls-hint[data-v-414ab6e3]{margin-top:1rem;text-align:center}.error[data-v-414ab6e3]{color:#ff6b6b;background:#ff6b6b1a;padding:1rem;border-radius:8px;margin-top:1rem}.game-footer[data-v-414ab6e3]{padding:1rem;text-align:center}.leave-btn[data-v-414ab6e3]{background:#ff6b6b;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;cursor:pointer}.leave-btn[data-v-414ab6e3]:hover{background:#ff5252}.desktop-controls[data-v-414ab6e3]{margin:.5rem 0}.mobile-controls[data-v-414ab6e3]{display:none}.touch-controls[data-v-414ab6e3]{display:flex;gap:1rem;justify-content:center;margin-top:1rem}.touch-btn[data-v-414ab6e3]{background:#fff3;color:#fff;border:2px solid #4ecdc4;border-radius:50%;width:60px;height:60px;font-size:1.5rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.touch-btn[data-v-414ab6e3]:active{background:#4ecdc4;transform:scale(.95)}@media (max-width: 768px){.desktop-controls[data-v-414ab6e3]{display:none}.mobile-controls[data-v-414ab6e3]{display:block}.touch-btn[data-v-414ab6e3]{width:50px;height:50px}}@media (max-width: 480px){.touch-btn[data-v-414ab6e3]{width:45px;height:45px;font-size:1.3rem}.touch-controls[data-v-414ab6e3]{gap:.5rem}}@media (max-width: 768px){.game[data-v-414ab6e3]{font-size:.9rem}.game-header[data-v-414ab6e3]{padding:.75rem}.game-info[data-v-414ab6e3]{flex-direction:column;gap:.5rem}.game-id[data-v-414ab6e3]{font-size:1rem}.scores[data-v-414ab6e3]{justify-content:center;gap:.5rem}.score[data-v-414ab6e3]{min-width:70px;padding:.4rem .8rem}.game-container[data-v-414ab6e3]{padding:1rem}.game-canvas[data-v-414ab6e3]{width:100%;max-width:400px;height:auto}.controls-hint[data-v-414ab6e3]{margin-top:.5rem}.controls-hint p[data-v-414ab6e3]{margin:.25rem 0;font-size:.85rem}.start-btn[data-v-414ab6e3]{padding:.8rem 1.5rem;font-size:1rem}.leave-btn[data-v-414ab6e3]{padding:.4rem .8rem;font-size:.9rem}.polygon-arena[data-v-414ab6e3]{padding:.5rem}.waiting h2[data-v-414ab6e3],.ready h2[data-v-414ab6e3]{font-size:1.5rem}.waiting p[data-v-414ab6e3],.ready p[data-v-414ab6e3]{font-size:.9rem}}@media (max-width: 480px){.game-header[data-v-414ab6e3]{padding:.5rem}.game-id[data-v-414ab6e3]{font-size:.9rem}.scores[data-v-414ab6e3]{gap:.25rem}.score[data-v-414ab6e3]{min-width:60px;padding:.3rem .6rem}.game-canvas[data-v-414ab6e3]{max-width:350px}.controls-hint[data-v-414ab6e3]{font-size:.8rem}.controls-hint p[data-v-414ab6e3]{margin:.2rem 0}.start-btn[data-v-414ab6e3]{padding:.7rem 1.2rem;font-size:.95rem}.leave-btn[data-v-414ab6e3]{padding:.35rem .7rem;font-size:.85rem}.waiting h2[data-v-414ab6e3],.ready h2[data-v-414ab6e3]{font-size:1.3rem}.waiting p[data-v-414ab6e3],.ready p[data-v-414ab6e3]{font-size:.85rem}}.join-game[data-v-101d9d42]{display:flex;justify-content:center;align-items:center;min-height:100vh;padding:20px}.join-container[data-v-101d9d42]{background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;padding:40px;text-align:center;box-shadow:0 8px 32px #0000004d;border:1px solid rgba(255,255,255,.2);max-width:500px;width:100%}.title[data-v-101d9d42]{font-size:2.5rem;font-weight:700;color:#fff;margin-bottom:40px;text-shadow:2px 2px 4px rgba(0,0,0,.5)}.form[data-v-101d9d42]{display:flex;flex-direction:column;gap:25px}.input-group[data-v-101d9d42]{text-align:left}.input-group label[data-v-101d9d42]{display:block;color:#fff;font-weight:500;margin-bottom:8px;font-size:1rem}.input[data-v-101d9d42]{width:100%;padding:15px 20px;font-size:1.1rem;border:none;border-radius:10px;background:#ffffffe6;color:#333;outline:none;transition:all .3s ease;box-sizing:border-box}.input[data-v-101d9d42]:focus{background:#fff;box-shadow:0 0 20px #ffffff4d}.buttons[data-v-101d9d42]{display:flex;flex-direction:column;gap:15px;margin-top:10px}.btn[data-v-101d9d42]{padding:15px 30px;font-size:1.1rem;font-weight:700;border:none;border-radius:10px;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:1px}.btn[data-v-101d9d42]:disabled{opacity:.6;cursor:not-allowed}.btn-primary[data-v-101d9d42]{background:linear-gradient(45deg,#4ecdc4,#44a08d);color:#fff;box-shadow:0 4px 15px #4ecdc466}.btn-primary[data-v-101d9d42]:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #4ecdc499}.btn-secondary[data-v-101d9d42]{background:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.3)}.btn-secondary[data-v-101d9d42]:hover{background:#fff3;transform:translateY(-1px)}.error[data-v-101d9d42]{background:#f003;color:#ff6b6b;padding:15px;border-radius:10px;border:1px solid rgba(255,107,107,.3);text-align:center}@media (max-width: 600px){.join-container[data-v-101d9d42]{padding:30px 20px}.title[data-v-101d9d42]{font-size:2rem}}*,*:before,*:after{box-sizing:border-box}*{margin:0;padding:0}html,body{height:100%;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}body{line-height:1.5;background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh}#app{height:100vh;width:100vw;display:flex;flex-direction:column}h1,h2,h3,h4,h5,h6{line-height:1.2;font-weight:600}button{font-family:inherit;font-size:inherit;border:none;background:none;cursor:pointer}input,textarea,select{font-family:inherit;font-size:inherit}button:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible{outline:2px solid rgba(255,255,255,.8);outline-offset:2px}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#ffffff1a}::-webkit-scrollbar-thumb{background:#ffffff4d;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#ffffff80}::selection{background:#ffffff4d;color:#fff}::-moz-selection{background:#ffffff4d;color:#fff}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInFromLeft{0%{opacity:0;transform:translate(-30px)}to{opacity:1;transform:translate(0)}}@keyframes slideInFromRight{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.fade-in{animation:fadeIn .6s ease-out}.slide-in-left{animation:slideInFromLeft .5s ease-out}.slide-in-right{animation:slideInFromRight .5s ease-out}.pulse{animation:pulse 2s infinite}@media (max-width: 768px){body{font-size:14px}}@media (max-width: 480px){body{font-size:13px}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}
