.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}