:root{color-scheme:dark;font-family:Segoe UI,system-ui,-apple-system,sans-serif;line-height:1.5;--bg: #0f0f1a;--bg2: #1a1a2e;--card: rgba(255,255,255,.04);--border: rgba(255,255,255,.08);--text: #e8e6f0;--muted: rgba(232,230,240,.5);--accent: #8b5cf6;--gold: #fbbf24;--red: #ef4444;--green: #22c55e;--yellow: #eab308;--blue: #3b82f6}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{min-height:100vh;background:var(--bg);color:var(--text)}.ludo-app{min-height:100vh;display:flex;align-items:center;justify-content:center}.menu-screen{text-align:center;padding:2rem;max-width:480px;width:100%}.menu-logo{margin-bottom:2.5rem}.menu-dice-icon{font-size:3rem;margin-bottom:.5rem;animation:bounce 2s ease-in-out infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.menu-logo h1{font-size:3rem;font-weight:800;letter-spacing:.15em;background:linear-gradient(135deg,var(--accent),var(--gold));-webkit-background-clip:text;-webkit-text-fill-color:transparent}.menu-subtitle{color:var(--muted);font-size:1rem}.menu-modes{display:flex;flex-direction:column;gap:.75rem}.mode-btn{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:1.25rem 1.5rem;background:var(--card);border:1px solid var(--border);border-radius:12px;color:var(--text);cursor:pointer;transition:all .2s;font-family:inherit}.mode-btn:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 4px 20px #8b5cf626}.mode-icon{font-size:1.5rem}.mode-label{font-size:1.1rem;font-weight:700}.mode-desc{font-size:.8rem;color:var(--muted)}.mode-duo:hover{border-color:var(--red);box-shadow:0 4px 20px #ef444426}.mode-ffa:hover{border-color:var(--green);box-shadow:0 4px 20px #22c55e26}.mode-online:hover{border-color:var(--blue);box-shadow:0 4px 20px #3b82f626}.game-layout{width:100%;max-width:640px;min-height:100vh;display:flex;flex-direction:column;padding:.75rem;gap:.75rem}.game-header{display:flex;align-items:center;justify-content:space-between;gap:1rem}.back-btn{background:var(--card);border:1px solid var(--border);color:var(--text);padding:.4rem .8rem;border-radius:8px;cursor:pointer;font-size:.85rem;font-family:inherit;transition:border-color .2s}.back-btn:hover{border-color:var(--accent)}.game-title{font-size:1.1rem;font-weight:700;letter-spacing:.05em}.turn-indicator{display:flex;gap:4px}.turn-dot{width:14px;height:14px;border-radius:50%;border:2px solid rgba(255,255,255,.2)}.color-red{background:var(--red)}.color-green{background:var(--green)}.color-yellow{background:var(--yellow)}.color-blue{background:var(--blue)}.status-bar{background:var(--card);border:1px solid var(--border);border-radius:10px;padding:.6rem 1rem}.teams-display{display:flex;justify-content:space-around;gap:.5rem}.team-info{display:flex;align-items:center;gap:.5rem;padding:.3rem .6rem;border-radius:8px;opacity:.5;transition:all .2s}.team-info.team-active{opacity:1;background:#8b5cf61a}.team-info.team-winner{opacity:1;background:#fbbf2426;border:1px solid rgba(251,191,36,.3)}.team-colors{display:flex;gap:3px}.team-dot{width:12px;height:12px;border-radius:50%;border:1.5px solid rgba(255,255,255,.3)}.team-label{font-size:.75rem;font-weight:600}.team-score{font-size:.75rem;color:var(--muted);font-family:monospace}.board-container{flex:1;display:flex;align-items:center;justify-content:center;min-height:0}.ludo-board{width:100%;max-width:560px;height:auto}.piece{transition:transform .15s}.piece:hover.piece-movable{transform:scale(1.15)}.piece-movable{cursor:pointer}.piece-glow{animation:pulse-glow 1.2s ease-in-out infinite}@keyframes pulse-glow{0%,to{opacity:.4;r:14}50%{opacity:1;r:18}}.controls{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding-bottom:1rem}.message-bar{font-size:.9rem;color:var(--muted);text-align:center;min-height:1.4rem}.controls-row{display:flex;align-items:center;gap:1rem}.dice-display{display:flex;align-items:center}.dice-face{width:48px;height:48px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:800;background:var(--bg2);border:2px solid var(--gold);border-radius:10px;color:var(--gold);animation:dice-pop .3s ease}@keyframes dice-pop{0%{transform:scale(.5) rotate(180deg);opacity:0}to{transform:scale(1) rotate(0);opacity:1}}.roll-btn{padding:.7rem 1.8rem;font-size:1rem;font-weight:700;font-family:inherit;background:linear-gradient(135deg,var(--accent),#6d28d9);color:#fff;border:none;border-radius:10px;cursor:pointer;transition:all .2s;box-shadow:0 0 20px #8b5cf64d}.roll-btn:hover:not(.roll-disabled){transform:translateY(-2px);box-shadow:0 0 30px #8b5cf680}.roll-disabled{opacity:.4;cursor:not-allowed}.hint{font-size:.8rem;color:var(--gold);opacity:.8;animation:hint-pulse 2s ease-in-out infinite}@keyframes hint-pulse{0%,to{opacity:.5}50%{opacity:1}}.lobby-form{display:flex;flex-direction:column;gap:1rem}.form-field{display:flex;flex-direction:column;gap:.35rem;text-align:left}.form-field label{font-size:.8rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}.lobby-input{padding:.7rem 1rem;background:#ffffff0a;border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:1rem;font-family:inherit;outline:none;transition:border-color .2s;text-align:center;letter-spacing:.15em}.lobby-input:focus{border-color:var(--accent)}.lobby-input::placeholder{color:var(--muted);letter-spacing:normal}.lobby-divider{display:flex;align-items:center;gap:1rem;color:var(--muted);font-size:.8rem}.lobby-divider:before,.lobby-divider:after{content:"";flex:1;height:1px;background:var(--border)}.lobby-error{color:var(--red);font-size:.85rem;background:#ef44441a;padding:.5rem 1rem;border-radius:8px}.lobby-hint{color:var(--muted);font-size:.85rem}.lobby-back{margin-top:1rem;width:100%;justify-content:center}.lobby-waiting{display:flex;flex-direction:column;align-items:center;gap:1.25rem}.room-code-display{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1.5rem 2rem;background:var(--card);border:1px solid var(--border);border-radius:12px;width:100%}.room-code-label{font-size:.75rem;color:var(--muted);text-transform:uppercase;letter-spacing:.1em}.room-code{font-size:2.5rem;font-weight:800;letter-spacing:.3em;color:var(--accent);font-family:monospace}.copy-btn{padding:.4rem 1.2rem;background:var(--card);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:.8rem;cursor:pointer;font-family:inherit;transition:border-color .2s}.copy-btn:hover{border-color:var(--accent)}.room-info{text-align:center}.room-info p{margin:.25rem 0}.room-players{color:var(--muted);font-size:.85rem}.mode-btn:disabled{opacity:.4;cursor:not-allowed;transform:none!important;box-shadow:none!important}.team-mine{border:1px solid var(--accent)!important;background:#8b5cf614!important;opacity:1!important}@media(max-width:480px){.game-layout{padding:.5rem;gap:.5rem}.teams-display{flex-direction:column;align-items:center}.team-label{font-size:.65rem}.dice-face{width:40px;height:40px;font-size:1.2rem}.roll-btn{padding:.6rem 1.4rem;font-size:.9rem}}
