.play-modal-overlay{position:fixed;z-index:1000;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.7)}.play-modal{position:relative;display:flex;flex-direction:column;align-items:stretch;width:100%;max-width:420px;padding:0 0 2rem;overflow:visible;background:#fff;border-radius:2rem;outline:none;box-shadow:0 8px 32px 0 rgba(0,0,0,.18)}.play-modal__close{position:absolute;top:1.25rem;right:1.25rem;z-index:2;font-size:2rem;color:#fff;background:none;border:none;cursor:pointer;transition:color .2s}.play-modal__close:active{color:#ffd100}@media(hover:hover){.play-modal__close:hover{color:#ffd100}}.play-modal__header{padding:2rem 1.5rem 1.25rem;text-align:center;background:linear-gradient(90deg,#08f,#ff6b00);border-top-left-radius:2rem;border-top-right-radius:2rem}.play-modal__title{margin-bottom:.25rem;font-family:Fredoka,sans-serif;font-size:2rem;font-weight:700;color:#fff}.play-modal__subtitle{margin-bottom:0;font-size:1rem;color:#fff;opacity:90%}.play-modal__options{display:flex;flex-direction:column;gap:1.25rem;padding:2rem 1.5rem 0}.play-modal__option{display:flex;gap:1rem;align-items:center;padding:1.25rem 1rem;font-family:Fredoka,sans-serif;font-size:1.1rem;font-weight:500;background:#fff;border:2px solid #eee;border-radius:1.25rem;outline:none;box-shadow:0 2px 8px 0 rgba(0,0,0,.04);cursor:pointer;transition:box-shadow .2s,transform .15s,border-color .2s,background .2s}.play-modal__option:active{background:#f8fafc;border-color:#ffd100;box-shadow:0 4px 24px 0 rgba(0,136,255,.1),0 0 0 4px rgba(255,209,0,.2);transform:scale(1.04)}@media(hover:hover){.play-modal__option:hover{background:#f8fafc;border-color:#ffd100;box-shadow:0 4px 24px 0 rgba(0,136,255,.1),0 0 0 4px rgba(255,209,0,.2);transform:scale(1.04)}}.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{background:#f8fafc;border-color:#ffd100;box-shadow:0 4px 24px 0 rgba(0,136,255,.1),0 0 0 4px rgba(255,209,0,.2);transform:scale(1.04)}.play-modal__icon{display:flex;align-items:center;justify-content:center;width:3.5rem;height:3.5rem;margin-right:1rem;font-size:2.5rem;background:#f0f6ff;border-radius:1rem}.play-modal__option--computer .play-modal__icon{color:#fff;background:#08f}.play-modal__option--friend .play-modal__icon{color:#fff;background:#ff6b00}.play-modal__option--online .play-modal__icon{color:#fff;background:#ffd100}.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;font-weight:400;color:#666}@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}}@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{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:2rem;background:linear-gradient(135deg,#667eea,#764ba2)}.online-game-lobby .lobby-container{display:flex;flex-direction:column;gap:2rem;width:100%;max-width:600px}.online-game-lobby .lobby-content{padding:2rem;text-align:center}.online-game-lobby .lobby-content h1{margin-bottom:1rem;font-size:2.5rem;text-shadow:2px 2px 4px rgba(0,0,0,.1);color:var(--primary-color)}.online-game-lobby .lobby-content>p{margin-bottom:2rem;font-size:1.2rem;color:var(--text-secondary)}.online-game-lobby .error-message{display:flex;gap:.5rem;align-items:center;margin-bottom:2rem;padding:1rem;color:#c33;background:#fee;border:1px solid #fcc;border-radius:8px}.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{margin-bottom:.5rem;font-size:1.5rem;color:var(--primary-color)}.online-game-lobby .action-section p{margin-bottom:1.5rem;color:var(--text-secondary)}.online-game-lobby .divider{position:relative;margin:1rem 0;text-align:center}.online-game-lobby .divider:before{position:absolute;top:50%;right:0;left:0;height:1px;background:var(--border-color);content:""}.online-game-lobby .divider span{padding:0 1rem;font-weight:500;color:var(--text-secondary);background:#fff}.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;font-family:Courier New,monospace;font-size:1rem;letter-spacing:2px;text-align:center;text-transform:uppercase;border:2px solid var(--border-color);border-radius:8px;transition:border-color .3s ease}.online-game-lobby .join-game-form .invite-code-input:focus{border-color:var(--primary-color);outline:none}.online-game-lobby .join-game-form .invite-code-input::-moz-placeholder{letter-spacing:normal;text-transform:none}.online-game-lobby .join-game-form .invite-code-input::placeholder{letter-spacing:normal;text-transform:none}.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;gap:.5rem;align-items:center;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:60%;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{padding:2rem;text-align:center}.invite-code-card .invite-code-display h3{margin-bottom:1rem;font-size:1.8rem;color:var(--success-color)}.invite-code-card .invite-code-display p{margin-bottom:1.5rem;color:var(--text-secondary)}.invite-code-card .invite-code-display .waiting-message{margin-top:1rem;font-style:italic;color:var(--warning-color)}.invite-code-card .invite-code-display .waiting-message i{margin-right:.5rem}.invite-code{display:flex;gap:1rem;align-items:center;justify-content:center;margin:1.5rem 0}.invite-code .code{padding:1rem 2rem;font-family:Courier New,monospace;font-size:2rem;font-weight:700;letter-spacing:4px;text-shadow:1px 1px 2px rgba(0,0,0,.1);color:var(--primary-color);background:var(--background-light);border:2px solid var(--primary-color);border-radius:12px}.invite-code .copy-btn{min-width:auto;padding:1rem;color:#fff;border:none;border-radius:50%;transition:all .3s ease}.invite-code .copy-btn:active{transform:scale(1.1)}@media(hover:hover){.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{padding:2px;color:var(--success-color);background:#fff;border-radius:50%}.online-game-waiting{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:2rem;background:linear-gradient(135deg,#667eea,#764ba2)}.online-game-waiting .waiting-container{width:100%;max-width:500px}.online-game-waiting .waiting-content{padding:3rem 2rem;text-align:center}.online-game-waiting .waiting-content h2{margin-bottom:1rem;font-size:2rem;color:var(--primary-color)}.online-game-waiting .waiting-content>p{margin-bottom:2rem;color:var(--text-secondary)}.online-game-waiting .share-options{margin-top:1.5rem}.online-game-waiting .share-options .share-btn{display:inline-flex;gap:.5rem;align-items:center;padding:.75rem 1.5rem;font-weight:600;color:#fff;background:var(--success-color);border:none;border-radius:8px;transition:all .3s ease}.online-game-waiting .share-options .share-btn:active{background:var(--success-dark);transform:translateY(-2px)}@media(hover:hover){.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;gap:.5rem;justify-content:center;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{font-size:1.1rem;font-style:italic;color:var(--text-secondary)}@keyframes pulse{0%,to{opacity:30%;transform:scale(1)}50%{opacity:100%;transform:scale(1.2)}}.online-game{position:relative}.online-game .online-status{position:fixed;top:1rem;right:1rem;z-index:1000;padding:1rem;background:hsla(0,0%,100%,.95);border:1px solid var(--border-color);border-radius:12px;box-shadow:0 4px 20px rgba(0,0,0,.1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.online-game .online-status .player-info{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem;font-size:.9rem}.online-game .online-status .player-info .you{font-weight:500;color:var(--text-primary)}.online-game .online-status .player-info .you strong{font-size:1.1rem;color:var(--primary-color)}.online-game .online-status .player-info .connection-status{display:flex;gap:.5rem;align-items:center;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;gap:.5rem;align-items:center;justify-content:center;width:100%;padding:.5rem 1rem;font-size:.85rem;color:#fff;background:var(--primary-color);border:none;border-radius:6px;transition:all .3s ease}.online-game .online-status .game-actions .copy-link-btn:active{background:var(--primary-dark);transform:translateY(-1px)}@media(hover:hover){.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{padding:.75rem 1.5rem;font-size:1.5rem;letter-spacing:2px}.online-status{position:relative!important;top:auto!important;right:auto!important;width:calc(100% - 2rem);margin:1rem}}.copy-toast{position:fixed;bottom:2rem;left:50%;z-index:10000;display:flex;gap:.5rem;align-items:center;padding:1rem 2rem;font-weight:500;color:#fff;background:var(--success-color);border-radius:8px;box-shadow:0 4px 20px rgba(0,0,0,.15);animation:slideUp .3s ease-out;transform:translateX(-50%)}.copy-toast i{font-size:1.1rem}@keyframes slideUp{0%{opacity:0;transform:translateX(-50%) translateY(20px)}to{opacity:100%;transform:translateX(-50%) translateY(0)}}:root{--success-color:#10b981;--success-dark:#059669;--warning-color:#f59e0b;--error-color:#ef4444;--background-light:#f8fafc}.loading-spinner{padding:2rem;text-align:center}.loading-spinner i{display:block;margin-bottom:1rem;font-size:2rem;color:var(--primary-color)}.loading-spinner p{margin:0;color:var(--text-secondary)}html{scroll-behavior:smooth}body,html{min-height:100vh;margin:0;padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left);font-family:var(--font-fredoka),"Fredoka",sans-serif;color:#222;background:#fff;-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-tap-highlight-color:rgba(0,0,0,0);-webkit-touch-callout:none}.form-input,.form-label,.form-select,.form-textarea{-webkit-user-select:text;-moz-user-select:text;user-select:text}*{box-sizing:border-box}::-webkit-scrollbar{display:none}