.play-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:1000;display:flex;align-items:center;justify-content:center}.play-modal{background:#fff;border-radius:2rem;box-shadow:0 8px 32px 0 rgba(0,0,0,.18);width:100%;max-width:420px;position:relative;overflow:visible;outline:none;padding:0 0 2rem;display:flex;flex-direction:column;align-items:stretch}.play-modal__close{position:absolute;top:1.25rem;right:1.25rem;background:none;border:none;font-size:2rem;color:#fff;z-index:2;cursor:pointer;transition:color .2s}.play-modal__close:hover{color:#ffd100}.play-modal__header{background:linear-gradient(90deg,#08f,#ff6b00);padding:2rem 1.5rem 1.25rem;text-align:center;border-top-left-radius:2rem;border-top-right-radius:2rem}.play-modal__title{font-family:Fredoka,sans-serif;font-size:2rem;font-weight:700;color:#fff;margin-bottom:.25rem}.play-modal__subtitle{color:#fff;opacity:.9;font-size:1rem;margin-bottom:0}.play-modal__options{display:flex;flex-direction:column;gap:1.25rem;padding:2rem 1.5rem 0}.play-modal__option{display:flex;align-items:center;background:#fff;border-radius:1.25rem;box-shadow:0 2px 8px 0 rgba(0,0,0,.04);padding:1.25rem 1rem;cursor:pointer;transition:box-shadow .2s,transform .15s,border-color .2s,background .2s;outline:none;border:2px solid #eee;font-family:Fredoka,sans-serif;font-size:1.1rem;font-weight:500;gap:1rem}.play-modal__option--computer{border-color:#08f}.play-modal__option--friend{border-color:#ff6b00}.play-modal__option--online{border-color:#ffd100}.play-modal__option:focus,.play-modal__option:hover{box-shadow:0 4px 24px 0 rgba(0,136,255,.1),0 0 0 4px rgba(255,209,0,.2);transform:scale(1.04);background:#f8fafc;border-color:#ffd100}.play-modal__icon{font-size:2.5rem;width:3.5rem;height:3.5rem;display:flex;align-items:center;justify-content:center;background:#f0f6ff;border-radius:1rem;margin-right:1rem}.play-modal__option--computer .play-modal__icon{background:#08f;color:#fff}.play-modal__option--friend .play-modal__icon{background:#ff6b00;color:#fff}.play-modal__option--online .play-modal__icon{background:#ffd100;color:#fff}.play-modal__labels{display:flex;flex-direction:column;align-items:flex-start}.play-modal__label{font-size:1.15rem;font-weight:700;color:#222}.play-modal__desc{font-size:.98rem;color:#666;font-weight:400}@media(width <= 600px){.play-modal{max-width:98vw;padding:0 0 1.5rem}.play-modal__header{padding:1.5rem 1rem 1rem}.play-modal__options{padding:1.5rem 1rem 0}}@import"https://fonts.googleapis.com/css2?family=Fredoka:wght@300;500;600;700&family=Rubik:wght@400;500;700&display=swap";@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}@keyframes bounce-slow{0%,to{transform:translateY(0) rotate(3deg)}50%{transform:translateY(-80px) rotate(3deg)}}@keyframes spin-slow{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.float{animation:float 6s ease-in-out infinite}.bounce-slow{animation:bounce-slow 3s infinite}.spin-slow{animation:spin-slow 8s linear infinite}.online-game-lobby{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background:linear-gradient(135deg,#667eea,#764ba2)}.online-game-lobby .lobby-container{max-width:600px;width:100%;display:flex;flex-direction:column;gap:2rem}.online-game-lobby .lobby-content{text-align:center;padding:2rem}.online-game-lobby .lobby-content h1{font-size:2.5rem;margin-bottom:1rem;color:var(--primary-color);text-shadow:2px 2px 4px rgba(0,0,0,.1)}.online-game-lobby .lobby-content>p{font-size:1.2rem;color:var(--text-secondary);margin-bottom:2rem}.online-game-lobby .error-message{background:#fee;border:1px solid #fcc;color:#c33;padding:1rem;border-radius:8px;margin-bottom:2rem;display:flex;align-items:center;gap:.5rem}.online-game-lobby .error-message i{font-size:1.2rem}.online-game-lobby .lobby-actions{display:flex;flex-direction:column;gap:2rem}.online-game-lobby .action-section{text-align:center}.online-game-lobby .action-section h3{font-size:1.5rem;margin-bottom:.5rem;color:var(--primary-color)}.online-game-lobby .action-section p{color:var(--text-secondary);margin-bottom:1.5rem}.online-game-lobby .divider{position:relative;text-align:center;margin:1rem 0}.online-game-lobby .divider:before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background:var(--border-color)}.online-game-lobby .divider span{background:#fff;padding:0 1rem;color:var(--text-secondary);font-weight:500}.online-game-lobby .join-game-form{display:flex;gap:1rem;max-width:400px;margin:0 auto}.online-game-lobby .join-game-form .invite-code-input{flex:1;padding:.75rem 1rem;border:2px solid var(--border-color);border-radius:8px;font-size:1rem;font-family:Courier New,monospace;text-align:center;text-transform:uppercase;letter-spacing:2px;transition:border-color .3s ease}.online-game-lobby .join-game-form .invite-code-input:focus{outline:none;border-color:var(--primary-color)}.online-game-lobby .join-game-form .invite-code-input::-moz-placeholder{text-transform:none;letter-spacing:normal}.online-game-lobby .join-game-form .invite-code-input::placeholder{text-transform:none;letter-spacing:normal}.online-game-lobby .join-game-form .join-game-btn{white-space:nowrap}.online-game-lobby .create-game-btn,.online-game-lobby .join-game-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 2rem;font-size:1rem;font-weight:600;transition:all .3s ease}.online-game-lobby .create-game-btn:disabled,.online-game-lobby .join-game-btn:disabled{opacity:.6;cursor:not-allowed}.online-game-lobby .create-game-btn i,.online-game-lobby .join-game-btn i{font-size:1.1rem}.invite-code-card .invite-code-display{text-align:center;padding:2rem}.invite-code-card .invite-code-display h3{font-size:1.8rem;margin-bottom:1rem;color:var(--success-color)}.invite-code-card .invite-code-display p{color:var(--text-secondary);margin-bottom:1.5rem}.invite-code-card .invite-code-display .waiting-message{color:var(--warning-color);font-style:italic;margin-top:1rem}.invite-code-card .invite-code-display .waiting-message i{margin-right:.5rem}.invite-code{display:flex;align-items:center;justify-content:center;gap:1rem;margin:1.5rem 0}.invite-code .code{font-family:Courier New,monospace;font-size:2rem;font-weight:700;color:var(--primary-color);background:var(--background-light);padding:1rem 2rem;border-radius:12px;border:2px solid var(--primary-color);letter-spacing:4px;text-shadow:1px 1px 2px rgba(0,0,0,.1)}.invite-code .copy-btn{padding:1rem;min-width:auto;border-radius:50%;color:#fff;border:none;transition:all .3s ease}.invite-code .copy-btn:hover{transform:scale(1.1)}.invite-code .copy-btn i{font-size:1.2rem;transition:all .3s ease}.invite-code .copy-btn i.fa-check{color:var(--success-color);background:#fff;border-radius:50%;padding:2px}.online-game-waiting{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background:linear-gradient(135deg,#667eea,#764ba2)}.online-game-waiting .waiting-container{max-width:500px;width:100%}.online-game-waiting .waiting-content{text-align:center;padding:3rem 2rem}.online-game-waiting .waiting-content h2{font-size:2rem;margin-bottom:1rem;color:var(--primary-color)}.online-game-waiting .waiting-content>p{color:var(--text-secondary);margin-bottom:2rem}.online-game-waiting .share-options{margin-top:1.5rem}.online-game-waiting .share-options .share-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:var(--success-color);color:#fff;border:none;border-radius:8px;font-weight:600;transition:all .3s ease}.online-game-waiting .share-options .share-btn:hover{background:var(--success-dark);transform:translateY(-2px)}.online-game-waiting .share-options .share-btn i{font-size:1.1rem}.online-game-waiting .waiting-animation{display:flex;justify-content:center;gap:.5rem;margin:2rem 0}.online-game-waiting .waiting-animation .pulse-dot{width:12px;height:12px;background:var(--primary-color);border-radius:50%;animation:pulse 1.5s ease-in-out infinite}.online-game-waiting .waiting-animation .pulse-dot:nth-child(2){animation-delay:.3s}.online-game-waiting .waiting-animation .pulse-dot:nth-child(3){animation-delay:.6s}.online-game-waiting .waiting-text{color:var(--text-secondary);font-style:italic;font-size:1.1rem}@keyframes pulse{0%,to{opacity:.3;transform:scale(1)}50%{opacity:1;transform:scale(1.2)}}.online-game{position:relative}.online-game .online-status{position:fixed;top:1rem;right:1rem;z-index:1000;background:hsla(0,0%,100%,.95);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px;padding:1rem;box-shadow:0 4px 20px rgba(0,0,0,.1);border:1px solid var(--border-color)}.online-game .online-status .player-info{display:flex;flex-direction:column;gap:.5rem;font-size:.9rem;margin-bottom:1rem}.online-game .online-status .player-info .you{color:var(--text-primary);font-weight:500}.online-game .online-status .player-info .you strong{color:var(--primary-color);font-size:1.1rem}.online-game .online-status .player-info .connection-status{display:flex;align-items:center;gap:.5rem;font-size:.85rem}.online-game .online-status .player-info .connection-status i{font-size:1rem}.online-game .online-status .player-info .connection-status i.fa-wifi{color:var(--success-color)}.online-game .online-status .player-info .connection-status i.fa-wifi-slash{color:var(--error-color)}.online-game .online-status .game-actions .copy-link-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.85rem;background:var(--primary-color);color:#fff;border:none;border-radius:6px;transition:all .3s ease;width:100%;justify-content:center}.online-game .online-status .game-actions .copy-link-btn:hover{background:var(--primary-dark);transform:translateY(-1px)}.online-game .online-status .game-actions .copy-link-btn i{font-size:.9rem;transition:all .3s ease}.online-game .online-status .game-actions .copy-link-btn i.fa-check{color:var(--success-color)}@media(width <= 768px){.online-game-lobby,.online-game-waiting{padding:1rem}.online-game-lobby .lobby-content,.online-game-lobby .waiting-content,.online-game-waiting .lobby-content,.online-game-waiting .waiting-content{padding:1.5rem}.online-game-lobby .lobby-content h1,.online-game-lobby .lobby-content h2,.online-game-lobby .waiting-content h1,.online-game-lobby .waiting-content h2,.online-game-waiting .lobby-content h1,.online-game-waiting .lobby-content h2,.online-game-waiting .waiting-content h1,.online-game-waiting .waiting-content h2{font-size:2rem}.online-game-lobby .join-game-form,.online-game-waiting .join-game-form{flex-direction:column;max-width:none}.online-game-lobby .join-game-form .invite-code-input,.online-game-waiting .join-game-form .invite-code-input{margin-bottom:0}.online-game-lobby .invite-code,.online-game-waiting .invite-code{flex-direction:column;gap:1rem}.online-game-lobby .invite-code .code,.online-game-waiting .invite-code .code{font-size:1.5rem;padding:.75rem 1.5rem;letter-spacing:2px}.online-status{position:relative!important;top:auto!important;right:auto!important;margin:1rem;width:calc(100% - 2rem)}}.copy-toast{position:fixed;bottom:2rem;left:50%;transform:translateX(-50%);background:var(--success-color);color:#fff;padding:1rem 2rem;border-radius:8px;box-shadow:0 4px 20px rgba(0,0,0,.15);display:flex;align-items:center;gap:.5rem;font-weight:500;z-index:10000;animation:slideUp .3s ease-out}.copy-toast i{font-size:1.1rem}@keyframes slideUp{0%{opacity:0;transform:translateX(-50%) translateY(20px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}:root{--success-color:#10b981;--success-dark:#059669;--warning-color:#f59e0b;--error-color:#ef4444;--background-light:#f8fafc}.loading-spinner{text-align:center;padding:2rem}.loading-spinner i{font-size:2rem;color:var(--primary-color);margin-bottom:1rem;display:block}.loading-spinner p{color:var(--text-secondary);margin:0}html{scroll-behavior:smooth}body,html{font-family:Fredoka,sans-serif;background:#fff;color:#222;margin:0;padding:0;min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}::-webkit-scrollbar{display:none}