*{margin:0;padding:0;box-sizing:border-box}body{-webkit-tap-highlight-color:transparent;background-color:#f8fafc;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;min-height:100dvh;overflow-y:auto;display:flex;flex-direction:column}#__next{min-height:100%}#__next,.game-container{display:flex;flex-direction:column;flex:1 1}.game-container{transition:background-color 1s ease;width:100%;position:relative}.game-view{display:grid;grid-template-rows:auto auto minmax(0,1fr) auto;grid-gap:.5rem;gap:.5rem;height:100dvh;overflow:hidden}.game-container.bg-rose{background-color:#fff1f2}.game-container.bg-indigo{background-color:#eef2ff}.game-container.bg-slate{background-color:#f8fafc}.header{position:static;padding:calc(.5rem + env(safe-area-inset-top)) 1rem .5rem;display:flex;flex-direction:column;justify-content:center;align-items:center;z-index:10;pointer-events:auto}.game-title{font-size:1.1rem;font-weight:900;color:#1e293b;font-style:italic;text-transform:uppercase;letter-spacing:.3em}.status-container{position:static;flex-direction:column;padding:0 1rem;width:100%;z-index:10}.mode-button,.status-container{display:flex;align-items:center}.mode-button{padding:.5rem 1.5rem;background-color:#e2e8f0;color:#475569;border-radius:9999px;font-size:.875rem;font-weight:600;border:none;cursor:pointer;transition:all .2s;box-shadow:0 2px 8px rgba(148,163,184,.15);margin-left:1rem;height:2.5rem;justify-content:center;min-width:120px}.mode-button:hover{background-color:#cbd5e1}.mode-button:disabled{opacity:.4;cursor:not-allowed;filter:grayscale(.3)}.mode-button:disabled:hover{background-color:#e2e8f0;transform:none}.victory-container{display:flex;flex-direction:column;align-items:center;z-index:50;animation:slideInUp .6s cubic-bezier(.17,.89,.32,1.49) forwards}.victory-badge{padding:.75rem 2rem;border-radius:9999px;box-shadow:0 25px 50px -12px rgba(0,0,0,.25);border:4px solid white;color:white}.victory-badge.red{background-color:#f43f5e}.victory-badge.blue{background-color:#6366f1}.reset-button{margin-top:.75rem;padding:.5rem 1.5rem;background-color:#1e293b;color:white;border-radius:9999px;font-size:.75rem;font-weight:700;border:none;cursor:pointer;transition:all .2s}.reset-button:disabled{opacity:.4;cursor:not-allowed;filter:grayscale(.3)}.turn-indicator{background-color:rgba(255,255,255,.95);padding:.5rem 1.5rem;border-radius:9999px;box-shadow:0 4px 15px rgba(0,0,0,.05);border:1px solid #f1f5f9;display:flex;align-items:center;gap:1rem;cursor:pointer;transition:all .2s}.turn-indicator:hover{background-color:rgba(248,250,252,.98);box-shadow:0 6px 20px rgba(0,0,0,.08);transform:translateY(-1px)}.turn-indicator.disabled{opacity:.4;cursor:not-allowed;filter:grayscale(.3);pointer-events:none}.turn-indicator.disabled:hover{background-color:rgba(255,255,255,.95);box-shadow:0 4px 15px rgba(0,0,0,.05);transform:none}.player-indicator{display:flex;align-items:center;gap:.5rem;opacity:.3;transition:all .3s ease}.player-indicator.active{opacity:1;font-weight:700;transform:scale(1.1)}.player-dot{width:.8rem;height:.8rem;border-radius:50%}.player-dot.red{background-color:#f43f5e}.player-dot.blue{background-color:#6366f1}.board-container{display:flex;align-items:center;justify-content:center;padding:.5rem;touch-action:none;min-height:0;overflow:hidden}.board-svg{width:100%;height:100%;max-height:600px;max-width:600px;overflow:visible;filter:drop-shadow(0 10px 15px rgba(0,0,0,.1))}.tile{transition:all .8s ease;fill:white;stroke:#e2e8f0;stroke-width:1px}.tile.selected-origin{fill:#fee2e2;stroke:#f43f5e;stroke-width:2px}.tile.destination-hint{fill:#f0fdf4;stroke:#34d399;stroke-dasharray:2}.tile.selectable-empty{fill:white;stroke:#fbbf24;stroke-width:2px;animation:tile-glow 2s ease-in-out infinite}.tile.victory-tile{fill:#fff1f2;stroke:#fda4af;stroke-width:4px}.tile.victory-tile.blue{fill:#eef2ff;stroke:#a5b4fc}.tile.faded{opacity:.2}.piece-main{transition:all .3s ease;stroke:rgba(0,0,0,.1);stroke-width:1px}.piece-main.red{fill:#f43f5e}.piece-main.blue{fill:#6366f1}.piece-main.selected{stroke:#fbbf24;stroke-width:8px;animation:selected-pulse .6s ease-in-out infinite}.piece-main.victory-piece{animation:piece-pulse 1.2s ease-in-out infinite}.piece-main.my-turn{stroke:#fbbf24;stroke-width:2px;animation:tile-glow 2s ease-in-out infinite}@keyframes piece-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.15)}}@keyframes tile-glow{0%,to{stroke-width:2px}50%{stroke-width:3px}}@keyframes selected-pulse{0%,to{transform:scale(1.35);stroke-width:8px}50%{transform:scale(1.5);stroke-width:10px}}@keyframes slideInUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes confetti-fall{0%{transform:translateY(-10vh) rotate(0deg);opacity:0}10%{opacity:1}to{transform:translateY(110vh) rotate(1turn);opacity:0}}@keyframes shuffle-bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.rules-container{position:static;padding:0 1rem calc(.5rem + env(safe-area-inset-bottom));width:100%;max-width:32rem;margin:.5rem auto 0;pointer-events:none;z-index:10}.rules-card{padding:0;display:flex;flex-direction:column;gap:.4rem;pointer-events:auto}.goal-box{background:#fffbeb;padding:.5rem .6rem;border-radius:.75rem;display:flex;gap:.5rem;align-items:center;font-size:.75rem;color:#78350f;border:1px solid #fde68a;cursor:pointer}.goal-hint{font-size:.7rem;color:#92400e;opacity:.85}.steps-grid{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:.75rem;gap:.75rem}.step-item{display:flex;gap:.5rem;align-items:center;color:#64748b;font-size:.7rem}.step-number{width:1.35rem;height:1.35rem;border-radius:50%;background-color:#1e293b;color:white;font-weight:700;flex-shrink:0}.loading-container,.step-number{display:flex;align-items:center;justify-content:center}.loading-container{flex-direction:column;flex:1 1;gap:16px;color:#64748b}.loading-spinner{width:48px;height:48px;border:4px solid #e2e8f0;border-top-color:#6366f1;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1 1;gap:24px;padding:24px}.error-message{color:#ef4444;font-size:14px;text-align:center}.back-button{padding:12px 24px;background:#6366f1;color:white;border:none;border-radius:9999px;font-weight:600;cursor:pointer}.back-button:hover{background:#4f46e5}.waiting-container{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1 1;padding:24px}.waiting-card{background:white;border-radius:16px;padding:32px;box-shadow:0 4px 24px rgba(0,0,0,.1);max-width:400px;width:100%;text-align:center}.room-code-box{margin-top:12px;padding:12px;border-radius:12px;background:#f8fafc;border:1px solid #e2e8f0}.room-code-label{font-size:12px;color:#64748b;letter-spacing:.08em;text-transform:uppercase;font-weight:700}.room-code-value{margin-top:6px;font-size:22px;font-weight:800;color:#1e293b;letter-spacing:.2em}.waiting-spinner{width:64px;height:64px;border:4px solid #e2e8f0;border-top-color:#6366f1;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 24px}.url-box{display:flex;gap:8px;margin-top:12px}.url-input{flex:1 1;padding:12px;border:1px solid #e2e8f0;border-radius:8px;font-size:12px;color:#64748b;background:#f8fafc}.copy-button{padding:12px 16px;background:#6366f1;color:white;border:none;border-radius:8px;font-weight:600;cursor:pointer;white-space:nowrap}.copy-button:hover{background:#4f46e5}.cancel-button{margin-top:24px;padding:12px 24px;background:transparent;color:#64748b;border:1px solid #e2e8f0;border-radius:9999px;font-weight:500;cursor:pointer}.cancel-button:hover{background:#f8fafc}.result-container{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1 1;padding:24px}.result-card{background:white;border-radius:16px;padding:32px;box-shadow:0 4px 24px rgba(0,0,0,.1);text-align:center}.play-again-button{margin-top:24px;padding:12px 24px;background:#6366f1;color:white;border:none;border-radius:9999px;font-weight:600;cursor:pointer}.play-again-button:hover{background:#4f46e5}.lobby-container{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1 1;padding:20px}.lobby-card{background:white;border-radius:16px;padding:32px;box-shadow:0 4px 24px rgba(0,0,0,.1);max-width:400px;width:100%;text-align:center}.lobby-actions{display:flex;flex-direction:column;gap:12px}.language-footer{position:fixed;left:0;right:0;bottom:calc(2.5rem + env(safe-area-inset-bottom));display:flex;justify-content:center;z-index:10;pointer-events:none}.language-toggle{pointer-events:auto;background:white;border:1px solid #e2e8f0;color:#4f46e5;font-size:.85rem;font-weight:700;padding:.5rem 1.25rem;border-radius:9999px;cursor:pointer;box-shadow:0 6px 16px rgba(15,23,42,.08);transition:all .2s ease}.language-toggle:hover{background:#eef2ff;border-color:#c7d2fe}.create-game-button{width:100%;padding:16px 24px;font-size:18px;font-weight:700;color:white;background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;border-radius:12px;cursor:pointer;transition:transform .2s,box-shadow .2s}.create-game-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 24px rgba(99,102,241,.4)}.create-game-button:disabled{opacity:.6;cursor:not-allowed}.lobby-button{width:100%;padding:14px 20px;font-size:16px;font-weight:700;border-radius:12px;border:1px solid #e2e8f0;background:white;color:#1e293b;cursor:pointer;transition:all .2s ease}.lobby-button:hover{background:#f8fafc;border-color:#cbd5e1}.lobby-button.secondary{background:#eef2ff;border-color:#c7d2fe;color:#4338ca}.lobby-button.secondary:hover{background:#e0e7ff}.lobby-button.primary{background:linear-gradient(135deg,#10b981,#22c55e);border:none;color:white}.lobby-button.primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 8px 20px rgba(16,185,129,.35)}.lobby-button.ghost{background:transparent;border:none;color:#64748b;text-decoration:underline}.lobby-button:disabled{opacity:.6;cursor:not-allowed}.join-title{font-size:1rem;font-weight:700;color:#1e293b;margin-bottom:16px}.room-join-form{display:flex;flex-direction:column;gap:12px}.room-code-input{width:100%;padding:12px 16px;border-radius:12px;border:1px solid #cbd5e1;font-size:18px;font-weight:700;text-align:center;letter-spacing:.2em;color:#1e293b}.room-code-input:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px rgba(99,102,241,.2)}.divider{display:flex;align-items:center;margin:24px 0}.divider:after,.divider:before{content:"";flex:1 1;height:1px;background:#e2e8f0}.divider span{padding:0 16px;color:#94a3b8;font-size:14px}.local-game-link{color:#6366f1;text-decoration:none;font-weight:500}.local-game-link:hover{text-decoration:underline}.shuffle-container{background-color:rgba(255,255,255,.98);padding:1rem 2rem;border-radius:1rem;box-shadow:0 10px 40px rgba(0,0,0,.15);border:2px solid #f1f5f9;animation:slideInUp .4s ease-out}.shuffle-text{font-size:.9rem;font-weight:700;color:#64748b;margin-bottom:.75rem;text-align:center}.shuffle-players{display:flex;gap:1.5rem;align-items:center}.shuffle-player{display:flex;flex-direction:column;align-items:center;gap:.5rem;animation:shuffle-bounce .6s ease-in-out infinite}.shuffle-player:first-child{animation-delay:0s}.shuffle-player:nth-child(2){animation-delay:.15s}.shuffle-avatar{width:3rem;height:3rem;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem}.shuffle-avatar.ai{background:linear-gradient(135deg,#f59e0b,#d97706);box-shadow:0 4px 12px rgba(245,158,11,.4)}.shuffle-avatar.human{background:linear-gradient(135deg,#6366f1,#4f46e5);box-shadow:0 4px 12px rgba(99,102,241,.4)}.shuffle-label{font-size:.75rem;font-weight:600;color:#475569}.mode-selector-overlay{position:fixed;inset:0;background-color:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:100;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.mode-selector-modal{background:white;border-radius:1.5rem;padding:1.5rem;box-shadow:0 25px 50px -12px rgba(0,0,0,.25);max-width:320px;width:calc(100% - 2rem);animation:slideInUp .3s cubic-bezier(.17,.89,.32,1.28)}.mode-selector-title{font-size:1.1rem;font-weight:800;color:#1e293b;text-align:center;margin-bottom:1.25rem}.mode-selector-options{display:flex;flex-direction:column;gap:.75rem}.mode-option{display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem;border:2px solid #e2e8f0;border-radius:1rem;background:white;cursor:pointer;transition:all .2s;font-size:1rem}.mode-option:hover{border-color:#6366f1;background:#f8fafc;transform:translateY(-2px);box-shadow:0 4px 12px rgba(99,102,241,.15)}.mode-option.active{border-color:#6366f1;background:#eef2ff}.mode-option.online{border-color:#34d399}.mode-option.online:hover{border-color:#10b981;background:#ecfdf5;box-shadow:0 4px 12px rgba(16,185,129,.15)}.mode-icon{font-size:1.5rem;width:2.5rem;height:2.5rem;display:flex;align-items:center;justify-content:center;background:#f1f5f9;border-radius:.75rem}.mode-option.online .mode-icon{background:#d1fae5}.mode-label{font-weight:600;color:#1e293b}