.game-end-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000d9;display:flex;justify-content:center;align-items:center;z-index:10000;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:fadeIn .3s ease-in}.game-end-modal{background:linear-gradient(145deg,#1a1a2e,#16213e);border-radius:20px;padding:40px;max-width:820px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #00000080;animation:slideUp .4s ease-out;border:2px solid rgba(255,255,255,.1)}@keyframes slideUp{0%{transform:translateY(50px);opacity:0}to{transform:translateY(0);opacity:1}}.game-end-header{text-align:center;margin-bottom:32px;padding:30px;border-radius:15px;animation:pulse 2s ease-in-out infinite}.game-end-header.victory{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 10px 30px #667eea66}.game-end-header.defeat{background:linear-gradient(135deg,#434343,#000);box-shadow:0 10px 30px #0006}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.02)}}.game-end-title{font-size:3rem;font-weight:800;color:#fff;margin:0 0 20px;text-shadow:0 4px 10px rgba(0,0,0,.3)}.winner-announcement{display:flex;flex-direction:column;align-items:center;gap:12px}.winner-label{font-size:1.1rem;font-weight:600;color:#ffffffd9;text-transform:uppercase;letter-spacing:1px}.winner-name{font-size:2rem;font-weight:800;color:gold;text-shadow:0 0 20px rgba(255,215,0,.5)}.winner-score{font-size:1.1rem;color:#ffffffbf}.winner-side-badge{display:inline-flex;align-items:center;gap:8px;font-size:1.8rem;font-weight:800;padding:10px 24px;border-radius:50px;letter-spacing:.5px;box-shadow:0 4px 15px #0006}.side-pill{display:inline-flex;align-items:center;gap:5px;font-size:.85rem;font-weight:700;padding:3px 10px;border-radius:50px;white-space:nowrap;box-shadow:0 2px 6px #0000004d}.side-text-light{color:#fff}.side-text-dark{color:#1a1a2e}.side-bg-0{background-color:var(--side-0)}.side-bg-1{background-color:var(--side-1)}.side-bg-2{background-color:var(--side-2)}.side-bg-3{background-color:var(--side-3)}.side-bg-4{background-color:var(--side-4)}.side-bg-5{background-color:var(--side-5)}.side-bg-6{background-color:var(--side-6)}.side-bg-7{background-color:var(--side-7)}.side-bg-8{background-color:var(--side-8)}.side-bg-9{background-color:var(--side-9)}.scores-breakdown{margin-bottom:28px}.scores-breakdown h3{color:gold;font-size:1.3rem;font-weight:700;margin-bottom:14px;text-align:center;letter-spacing:.5px;text-transform:uppercase}.scores-table{background:#ffffff0d;border-radius:12px;overflow:hidden}.scores-table-header.side-rankings-header,.scores-table-row.side-rankings-row{grid-template-columns:70px 1fr 1fr 100px}.scores-table-header.player-stats-header{grid-template-columns:60px 1fr 2fr 100px}.scores-table-header{display:grid;gap:12px;padding:13px 18px;background:#ffffff1a;font-weight:700;font-size:.85rem;text-transform:uppercase;letter-spacing:.5px;color:gold;border-bottom:2px solid rgba(255,215,0,.3)}.scores-table-row{display:grid;grid-template-columns:60px 1fr 2fr 100px;gap:12px;padding:13px 18px;border-bottom:1px solid rgba(255,255,255,.05);transition:background .2s ease;color:#fff;animation:rowFadeIn .4s ease-out backwards;align-items:center}@keyframes rowFadeIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.scores-table-row:nth-child(2){animation-delay:.05s}.scores-table-row:nth-child(3){animation-delay:.1s}.scores-table-row:nth-child(4){animation-delay:.15s}.scores-table-row:nth-child(5){animation-delay:.2s}.scores-table-row:nth-child(6){animation-delay:.25s}.scores-table-row:hover{background:#ffffff14}.scores-table-row.current-player{background:#4ade8026;border:1px solid rgba(74,222,128,.3)}.scores-table-row.winning-row{background:#ffd7001a;border-left:3px solid #ffd700}.rank{font-weight:700;font-size:1.1rem;color:gold}.player-name,.player-name-cell{font-weight:600;color:#fff}.side-name-cell{display:flex;align-items:center}.player-sides{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.side-score-entry{display:flex;align-items:center;gap:6px}.side-score-value{font-weight:700;font-size:.95rem;color:#e2e8f0}.total-score{font-weight:700;font-size:1.2rem;color:#4ade80}.game-end-actions{display:flex;justify-content:center;gap:20px;margin-top:30px}.btn-primary,.btn-secondary{padding:14px 36px;font-size:1.1rem;font-weight:700;border:none;border-radius:12px;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:1px;box-shadow:0 4px 15px #0000004d}.btn-primary:hover{transform:translateY(-3px);box-shadow:0 6px 25px #667eea80}.btn-secondary{background:linear-gradient(135deg,#434343,#000);color:#fff}.btn-secondary:hover{transform:translateY(-3px);box-shadow:0 6px 25px #00000080}.game-end-modal::-webkit-scrollbar{width:10px}.game-end-modal::-webkit-scrollbar-track{background:#ffffff0d;border-radius:10px}.game-end-modal::-webkit-scrollbar-thumb{background:#fff3;border-radius:10px}.game-end-modal::-webkit-scrollbar-thumb:hover{background:#ffffff4d}@media(max-width:480px){.game-end-modal{padding:15px}.game-end-header{padding:20px 15px;margin-bottom:20px}.game-end-title{font-size:1.6rem;margin-bottom:12px}.winner-name{font-size:1.4rem}.winner-side-badge{font-size:1.3rem;padding:8px 16px}.scores-breakdown h3{font-size:1rem}.btn-primary,.btn-secondary{padding:12px 20px;font-size:.95rem}}@media(max-width:768px){.game-end-modal{padding:20px;max-width:95%}.game-end-title{font-size:2rem}.scores-table-header.side-rankings-header,.scores-table-row.side-rankings-row{grid-template-columns:50px 1fr 80px}.scores-table-row.side-rankings-row .player-name-cell,.scores-table-header.side-rankings-header span:nth-child(3){display:none}.scores-table-header.player-stats-header,.scores-table-row{grid-template-columns:50px 1fr 90px}.player-sides{display:none}.scores-table-header.player-stats-header span:nth-child(3){display:none}.game-end-actions{flex-direction:column}.btn-primary,.btn-secondary{width:100%}}.game-board-container{display:flex;flex-direction:column;gap:8px;padding:8px;width:100%;max-width:1400px;margin:0 auto;height:100%;overflow:auto;box-sizing:border-box;background:var(--bg-primary, #1a1a2e)}.game-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px;background:linear-gradient(135deg,#667eea26,#764ba226);border-radius:10px;padding:12px 20px;border:1px solid rgba(102,126,234,.3)}.current-turn h3{color:#333;margin-bottom:10px;font-size:1.2em}.turn-indicator{display:flex;align-items:center;gap:10px;padding:12px 20px;border-radius:10px;color:#fff;font-weight:700;transition:all .3s ease;min-width:150px;justify-content:center}.turn-indicator.your-turn{animation:pulse-glow 2s infinite;box-shadow:0 0 20px #ffffff4d}@keyframes pulse-glow{0%,to{box-shadow:0 0 20px #ffffff4d}50%{box-shadow:0 0 30px #fff9}}.turn-icon{font-size:1.5em}.turn-text{font-size:1.1em}.player-info{text-align:center}.player-info h4{color:#333;margin-bottom:10px;font-size:1.1em}.your-color{width:60px;height:60px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2em;color:#fff;margin:0 auto;box-shadow:0 4px 15px #0003}.player-sides{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin-top:10px}.side-chip{display:flex;align-items:center;gap:4px;padding:6px 10px;border-radius:20px;color:#fff;font-weight:700;transition:all .3s ease;box-shadow:0 2px 8px #0003}.side-chip.active{transform:scale(1.1);box-shadow:0 4px 15px #0000004d;animation:pulse-glow 2s infinite}.side-chip .side-icon{font-size:1.2em}.side-chip .side-number{font-size:.9em}.round-info{background:linear-gradient(135deg,#f9ca241a,#fd79a81a);border-radius:12px;padding:15px;text-align:center;border:1px solid rgba(249,202,36,.3)}.round-info h4{color:#333;margin-bottom:10px;font-size:1.3em;background:linear-gradient(135deg,#f9ca24,#fd79a8);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.moves-left{color:#666;font-size:1.1em;margin:5px 0}.moves-left strong{color:#f9ca24;font-size:1.3em}.moves-rule{color:#888;font-size:.9em;font-style:italic;margin-top:8px}.board-wrapper{display:flex;flex-direction:column;align-items:center;margin-bottom:30px}.coordinate-labels{margin-bottom:10px}.file-labels{display:flex;gap:2px;margin-left:40px}.file-label{width:45px;height:20px;display:flex;align-items:center;justify-content:center;font-weight:700;color:#666;font-size:.9em}.board-with-ranks{display:flex;align-items:flex-start}.rank-labels{display:flex;flex-direction:column;gap:2px;margin-right:10px;margin-top:1px}.rank-label{width:30px;height:45px;display:flex;align-items:center;justify-content:center;font-weight:700;color:#666;font-size:.9em}.board{display:flex;flex-direction:column;gap:2px;background:#8b4513;padding:10px;border-radius:10px;box-shadow:0 8px 30px #0000004d;border:3px solid #654321}.row{display:flex;gap:2px}.cell{width:45px;height:45px;display:flex;align-items:center;justify-content:center;cursor:pointer;position:relative;transition:all .2s ease;border-radius:4px}.cell.light,.cell.dark{background:#fff;border:1px solid #e0e0e0}.cell:hover{transform:scale(1.05);box-shadow:0 2px 8px #0000004d;z-index:10}.cell.selected{background:#ffeb3b!important;box-shadow:0 0 15px #ffeb3bcc;transform:scale(1.1);z-index:20}.cell.valid-move{background:#90ee90!important;box-shadow:0 0 10px #4caf5099;border:2px solid #4caf50!important}.cell.valid-move:after{content:"";position:absolute;width:12px;height:12px;background:#fff;border-radius:50%;box-shadow:0 2px 4px #0000004d}.cell.start-zone-1{background:linear-gradient(135deg,#ff6b6b4d,#ff6b6b1a)}.cell.start-zone-2{background:linear-gradient(135deg,#4ecdc44d,#4ecdc41a)}.cell.owned{position:relative;border:2px solid rgba(0,0,0,.2)!important}.cell.owned:before{content:"";position:absolute;top:2px;right:2px;bottom:2px;left:2px;border-radius:3px;opacity:.3;pointer-events:none}.cell.territory-1{background:#ff6b6b!important;border-color:#f44!important}.cell.territory-2{background:#4ecdc4!important;border-color:#2ca09a!important}.cell.territory-3{background:#45b7d1!important;border-color:#2990a8!important}.cell.territory-4{background:#f9ca24!important;border-color:#e0a800!important}.cell.territory-5{background:#6c5ce7!important;border-color:#5040c0!important}.cell.territory-6{background:#fd79a8!important;border-color:#fc5088!important}.cell.territory-7{background:#00b894!important;border-color:#00906f!important}.cell.territory-8{background:#fdcb6e!important;border-color:#fcb040!important}.cell.territory-9{background:#636e72!important;border-color:#4a5355!important}.cell.territory-0{background:#a29bfe!important;border-color:#8078fe!important}@keyframes territory-capture{0%{transform:scale(1)}50%{transform:scale(1.2)}to{transform:scale(1)}}.cell.owned{animation:territory-capture .5s ease-out}.cell.burned{background:linear-gradient(135deg,#2c1810,#1a0e08,#3d2418)!important;position:relative;overflow:hidden}.cell.burned:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:url("data:image/svg+xml,%3Csvg width='100' height='100' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0 0L50 50L0 100M50 0L100 50L50 100' stroke='%23ff4444' stroke-width='0.5' fill='none' opacity='0.2'/%3E%3C/svg%3E") center/20px 20px;animation:burn-flicker 3s infinite}.cell.burned:after{content:"🔥";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:20px;opacity:.3;animation:fire-dance 2s infinite}@keyframes burn-flicker{0%,to{opacity:.2}50%{opacity:.4}}@keyframes fire-dance{0%,to{transform:translate(-50%,-50%) scale(1)}25%{transform:translate(-45%,-55%) scale(1.1)}50%{transform:translate(-55%,-50%) scale(.9)}75%{transform:translate(-50%,-45%) scale(1.05)}}.piece{font-size:2em;font-weight:700;text-shadow:1px 1px 2px rgba(0,0,0,.5);z-index:5;transition:all .2s ease}.piece:hover{transform:scale(1.2)}.piece.fan-piece{opacity:.5;font-size:1.6em;animation:fan-piece-pulse 2s ease-in-out infinite}.piece.fan-piece:after{content:"↗";position:absolute;font-size:.5em;top:-5px;right:-5px;opacity:.8}@keyframes fan-piece-pulse{0%,to{opacity:.5}50%{opacity:.8}}.cell.blocked-piece{position:relative;opacity:.5;cursor:not-allowed}.cell.blocked-piece:after{content:"⛔";position:absolute;top:-5px;right:-5px;font-size:.8em;filter:drop-shadow(0 1px 2px rgba(0,0,0,.5))}.cell.blocked-piece .piece{filter:grayscale(50%);cursor:not-allowed}.cell.blocked-piece:hover{transform:none!important;box-shadow:0 1px 3px #ff00004d}.cell-coordinate{position:absolute;bottom:1px;right:2px;font-size:.6em;color:#0006;font-weight:700;pointer-events:none}.game-controls{display:flex;justify-content:center;align-items:center;gap:20px;margin-bottom:30px;background:#fffc;border-radius:15px;padding:20px}.control-btn{padding:12px 24px;border:none;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:8px;cursor:pointer;font-weight:600;transition:all .3s ease}.control-btn:disabled{background:#ccc;cursor:not-allowed;opacity:.6}.control-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 15px #667eea4d}.move-hint{flex:1;text-align:center}.move-hint p{margin:0;color:#666;font-size:1.1em;font-weight:500}.game-info-sidebar{background:#ffffffe6;border-radius:15px;padding:25px;border:1px solid rgba(102,126,234,.2)}.current-scores{margin-bottom:30px;background:linear-gradient(135deg,#667eea0d,#764ba20d);border-radius:12px;padding:15px}.current-scores h4{color:#333;margin-bottom:15px;font-size:1.2em;text-align:center;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.scores-list{display:flex;flex-direction:column;gap:8px}.score-item{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border-radius:8px;background:#fff;transition:all .3s ease;border-left-width:4px!important;border-left-style:solid}.score-item:hover{transform:translate(4px);box-shadow:0 2px 8px #0000001a}.score-item.player-score{font-weight:700;box-shadow:0 2px 10px #667eea33}.score-item.active-turn{background:linear-gradient(90deg,#ffeb3b33,#ffeb3b1a);border:2px solid #fdd835;box-shadow:0 0 12px #ffeb3b66;animation:pulse 1.5s ease-in-out infinite}.score-item.active-turn.player-side{background:linear-gradient(90deg,#4caf5033,#4caf501a);border:2px solid #4caf50;box-shadow:0 0 15px #4caf5080;animation:player-turn-pulse 1.5s ease-in-out infinite}@keyframes player-turn-pulse{0%,to{transform:translate(0);box-shadow:0 0 15px #4caf5080}50%{transform:translate(5px);box-shadow:0 0 25px #4caf50cc,0 0 40px #4caf5066}}.your-turn-banner{position:fixed;top:0;left:50%;transform:translate(-50%);background:linear-gradient(135deg,#4caf50,#2e7d32);color:#fff;padding:12px 32px;font-size:1.3em;font-weight:700;border-radius:0 0 12px 12px;box-shadow:0 4px 20px #0000004d;z-index:1000;animation:banner-bounce .5s ease-out,banner-pulse 2s ease-in-out infinite .5s}@keyframes banner-bounce{0%{transform:translate(-50%) translateY(-100%)}60%{transform:translate(-50%) translateY(10px)}to{transform:translate(-50%) translateY(0)}}@keyframes banner-pulse{0%,to{box-shadow:0 4px 20px #0000004d}50%{box-shadow:0 4px 30px #4caf5080,0 0 50px #4caf504d}}.your-turn-banner .banner-icon{margin-right:8px;font-size:1.2em}.your-turn-banner .dismiss-btn{margin-left:16px;background:#fff3;border:none;color:#fff;padding:4px 12px;border-radius:4px;cursor:pointer;transition:background .2s}.your-turn-banner .dismiss-btn:hover{background:#ffffff4d}@media(max-width:480px){.your-turn-banner{padding:8px 16px;font-size:1em;width:90%;left:50%;transform:translate(-50%);text-align:center}.your-turn-banner .dismiss-btn{margin-left:8px;padding:3px 8px}}@keyframes pulse{0%{transform:translate(0);box-shadow:0 0 12px #ffeb3b66}50%{transform:translate(3px);box-shadow:0 0 20px #ffeb3b99}to{transform:translate(0);box-shadow:0 0 12px #ffeb3b66}}.side-icon{font-size:1.3em;min-width:30px;text-align:center}.side-label{flex:1;margin:0 10px;color:#555;font-size:.95em}.score-value{font-weight:600;color:#667eea;font-size:1.1em;min-width:40px;text-align:right}.game-info-sidebar h4{color:#333;margin-bottom:15px;font-size:1.3em;text-align:center}.movement-pattern{text-align:center}.pattern-grid{display:inline-block;margin-bottom:15px;background:#f5f5f5;border-radius:8px;padding:10px;border:2px solid #ddd}.pattern-row{display:flex}.pattern-cell{width:30px;height:30px;display:flex;align-items:center;justify-content:center;margin:1px;border-radius:3px;font-weight:700}.pattern-cell.center{background:#667eea;color:#fff;font-size:1.2em}.pattern-cell.valid{background:#4caf50;color:#fff;font-size:1.5em}.pattern-cell.invalid{background:#f0f0f0}.movement-pattern p{color:#666;font-size:.9em;line-height:1.4;margin:0}.game-over{text-align:center;padding:50px;background:linear-gradient(135deg,#667eea1a,#764ba21a);border-radius:20px;border:2px solid rgba(102,126,234,.3)}.game-over h2{color:#333;font-size:3em;margin-bottom:20px;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.game-over p{font-size:1.5em;color:#666;margin-bottom:30px}.winner-announcement{font-size:1.8em;color:#667eea;margin:20px 0;font-weight:700}.final-scores{background:#ffffffe6;border-radius:15px;padding:20px;margin:30px auto;max-width:500px}.final-scores h3{color:#333;margin-bottom:15px;font-size:1.3em}.score-row{display:flex;justify-content:space-between;align-items:center;padding:12px 15px;margin:8px 0;background:#667eea0d;border-radius:8px;transition:all .3s ease}.score-row.player-score{background:linear-gradient(135deg,#667eea33,#764ba233);border:2px solid rgba(102,126,234,.5);font-weight:700}.side-info{color:#555;font-size:1.1em}.score-details{color:#667eea;font-size:1.2em;font-weight:600}.new-game-btn{margin-top:30px;padding:15px 40px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:10px;font-size:1.2em;font-weight:700;cursor:pointer;transition:all .3s ease}.new-game-btn:hover{transform:translateY(-3px);box-shadow:0 10px 30px #667eea66}.winner-celebration{display:flex;justify-content:center;align-items:center;gap:20px;font-size:3em;animation:celebration 2s infinite;margin:20px 0}@keyframes celebration{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.confetti{animation:confetti-fall 3s infinite}@keyframes confetti-fall{0%{transform:translateY(-20px) rotate(0);opacity:1}to{transform:translateY(20px) rotate(360deg);opacity:.5}}.trophy{animation:trophy-glow 2s infinite}@keyframes trophy-glow{0%,to{filter:drop-shadow(0 0 10px gold)}50%{filter:drop-shadow(0 0 20px gold)}}.cell.ai-move-from{background:#ffc107!important;box-shadow:0 0 20px #ffc107cc;animation:ai-pulse-from 1.5s ease-out;position:relative}.cell.ai-move-from:after{content:"↗";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:1.5em;color:#fffc;animation:ai-arrow-fade 1.5s ease-out}.cell.ai-move-to{background:#ff5722!important;box-shadow:0 0 25px #ff5722e6;animation:ai-pulse-to 1.5s ease-out;position:relative}.cell.ai-move-to:before{content:"🎯";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:1.2em;animation:ai-target-pulse 1.5s ease-out;z-index:10}@keyframes ai-pulse-from{0%{transform:scale(1);box-shadow:0 0 10px #ffc10766}25%{transform:scale(1.2);box-shadow:0 0 30px #ffc107}to{transform:scale(1);box-shadow:0 0 20px #ffc107cc}}@keyframes ai-pulse-to{0%{transform:scale(1);box-shadow:0 0 10px #ff572266}50%{transform:scale(1.15);box-shadow:0 0 35px #ff5722}to{transform:scale(1);box-shadow:0 0 25px #ff5722e6}}@keyframes ai-arrow-fade{0%{opacity:0;transform:translate(-50%,-50%) scale(.5)}50%{opacity:1;transform:translate(-50%,-50%) scale(1.2)}to{opacity:.8;transform:translate(-50%,-50%) scale(1)}}@keyframes ai-target-pulse{0%{opacity:0;transform:translate(-50%,-50%) scale(0)}50%{opacity:1;transform:translate(-50%,-50%) scale(1.3)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}@media(max-width:768px){.game-board-container{padding:10px}.game-header{flex-direction:column;gap:20px;text-align:center}.cell,.file-label,.rank-label{width:35px;height:35px}.piece{font-size:1.5em}.game-controls{flex-direction:column;gap:15px}.file-labels{margin-left:30px}.rank-label{width:25px}}@media(max-width:480px){.cell{width:28px;height:28px}.file-label,.rank-label{width:28px;height:28px;font-size:.8em}.piece{font-size:1.2em}.board{padding:5px}.game-over h2,.winner-celebration{font-size:2em}}.skip-notification{position:relative;animation:slide-in .4s ease-out;margin-bottom:10px}.skip-notification-content{display:flex;align-items:center;gap:15px;padding:15px 20px;background:linear-gradient(135deg,#ff9500,#ff5e3a);border-radius:var(--radius-md);border:2px solid #ffaa00;box-shadow:0 4px 12px #ff950066;color:#fff}.skip-icon{font-size:28px;animation:bounce 1s infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.skip-message{flex:1}.skip-message strong{display:block;font-size:16px;margin-bottom:4px}.skip-message p{margin:0;font-size:14px;opacity:.95}.skip-dismiss{background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff;width:28px;height:28px;border-radius:50%;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:all .2s;padding:0}.skip-dismiss:hover{background:#ffffff4d;transform:scale(1.1)}.game-info-header{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:8px 16px;background:#1f2937f2;border-radius:var(--radius-md);border:1px solid var(--accent-primary);min-height:50px;flex-shrink:0;flex-wrap:wrap}.info-items{display:flex;gap:16px;align-items:center;flex-wrap:wrap;flex:1;min-width:0}.header-controls{display:flex;gap:8px;align-items:center;flex-shrink:0;margin-left:auto;flex-wrap:nowrap}.header-btn{display:inline-flex;align-items:center;justify-content:center;gap:4px;padding:0 12px;border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-sm, 4px);font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap;min-width:70px;height:34px;line-height:1;margin:0;vertical-align:middle;box-sizing:border-box;background:#ffffff1f;color:#fff}.header-btn:hover{background:#ffffff38;transform:translateY(-1px);box-shadow:0 2px 8px #0000004d}.header-btn:disabled{opacity:.4;cursor:not-allowed;transform:none;box-shadow:none}.info-item{display:flex;align-items:center;gap:8px}.info-label{color:var(--text-secondary);font-weight:700}.info-value{color:var(--text-primary);font-size:18px}.info-note{color:var(--accent-primary);font-size:14px;font-style:italic}.info-item.winner .info-value{color:var(--accent-primary);font-weight:700;animation:glow-pulse 1s infinite}.game-content{display:flex;gap:20px;flex:1;min-height:0;overflow:auto;align-items:flex-start;justify-content:center;padding:8px}.board-with-coordinates{--available-width: calc(100vw - 320px) ;--available-height: calc(100vh - 160px) ;--coord-size: 24px;--cell-size-from-width: calc((var(--available-width) - var(--coord-size)) / 11);--cell-size-from-height: calc((var(--available-height) - var(--coord-size) * 2) / 11);--cell-size: min(var(--cell-size-from-width), var(--cell-size-from-height));display:inline-grid;grid-template-columns:var(--coord-size) repeat(11,minmax(0,var(--cell-size)));grid-template-rows:var(--coord-size) repeat(11,minmax(0,var(--cell-size))) var(--coord-size);background:var(--bg-secondary);padding:8px;border-radius:var(--radius-md);gap:0;flex-shrink:0;width:fit-content;height:fit-content;overflow:hidden}.board-corner{background:transparent}.coord-label{display:flex;align-items:center;justify-content:center;font-size:calc(var(--coord-size, 24px) * .58);font-weight:600;color:var(--text-secondary);-webkit-user-select:none;user-select:none;overflow:hidden;min-width:0;min-height:0}.coord-horizontal,.coord-vertical{background:var(--bg-secondary)}.game-board{display:inline-block;background:var(--bg-secondary);padding:10px;border-radius:var(--radius-md)}.board-row{display:flex}.board-cell{width:100%;height:100%;min-width:0;min-height:0;border:1px solid #333;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background-color .2s ease,border-color .2s ease,box-shadow .2s ease,opacity .2s ease;position:relative;overflow:hidden;box-sizing:border-box}.board-cell:hover{opacity:.8}.board-cell.side-0{background-color:#f44}.board-cell.side-1{background-color:#48f}.board-cell.side-2{background-color:#4d4}.board-cell.side-3{background-color:#ff4}.board-cell.side-4{background-color:#d6f}.board-cell.side-5{background-color:#f84}.board-cell.side-6{background-color:#f6a}.board-cell.side-7{background-color:#4dd}.board-cell.side-8{background-color:#a64}.board-cell.side-9{background-color:var(--side-9)}.board-cell.burned{background:linear-gradient(135deg,#2c1810,#1a0e08,#3d2418)!important;cursor:not-allowed}.board-cell.burned:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:url("data:image/svg+xml,%3Csvg width='100' height='100' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0 0L50 50L0 100M50 0L100 50L50 100' stroke='%23ff4444' stroke-width='0.5' fill='none' opacity='0.2'/%3E%3C/svg%3E") center/20px 20px;animation:burn-flicker 3s infinite}.board-cell.burned:after{content:"🔥";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:20px;opacity:.3;animation:fire-dance 2s infinite}.board-cell.active-field{box-shadow:inset 0 0 0 3px #ffffffb3}.board-cell.active-field:before{content:"";position:absolute;width:8px;height:8px;background:#ffffffe6;border-radius:50%;top:5px;right:5px;animation:pulse-dot 1.5s ease-in-out infinite;z-index:10}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(1.3)}}.board-cell.can-move-now{animation:glow-pulse 2s infinite;box-shadow:0 0 15px #fffc}.board-cell.player-can-move{border:3px solid #00ff00!important;box-shadow:0 0 25px #0f0c,inset 0 0 15px #0f06;animation:player-ready-pulse 2s ease-in-out infinite}@keyframes player-ready-pulse{0%,to{box-shadow:0 0 25px #0f0c,inset 0 0 15px #0f06}50%{box-shadow:0 0 35px #0f0,inset 0 0 20px #0f09}}.board-cell.blocked-piece{opacity:.7;cursor:not-allowed!important;position:relative}.board-cell.blocked-piece:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:repeating-linear-gradient(45deg,transparent,transparent 10px,rgba(0,0,0,.2) 10px,rgba(0,0,0,.2) 20px);pointer-events:none}.board-cell.blocked-piece .piece{opacity:.5;filter:grayscale(50%)}.board-cell.blocked-piece:hover{opacity:.7!important;transform:none!important}.board-cell.available-move{box-shadow:0 0 0 2px #0f0;background-color:#0f03!important;cursor:pointer}.board-cell.available-move:hover{background-color:#0f06!important;transform:scale(1.05)}.board-cell.selected{box-shadow:0 0 0 3px #fff;transform:scale(1.1)}.board-cell.ai-move-from{animation:ai-move-from-pulse 1.5s ease;box-shadow:0 0 20px #ff0c}.board-cell.ai-move-to{animation:ai-move-to-pulse 1.5s ease;box-shadow:0 0 20px #0ffc}@keyframes ai-move-from-pulse{0%{transform:scale(1);box-shadow:0 0 #ff00}25%{transform:scale(1.2);box-shadow:0 0 30px #ff0}to{transform:scale(1);box-shadow:0 0 #ff00}}@keyframes ai-move-to-pulse{0%{transform:scale(1);box-shadow:0 0 #0ff0}50%{transform:scale(1.15);box-shadow:0 0 25px #0ff}to{transform:scale(1);box-shadow:0 0 #0ff0}}.board-cell .piece{position:absolute;top:0;right:0;bottom:0;left:0;margin:auto;width:fit-content;height:fit-content;font-size:calc(var(--cell-size, 40px) * .6);text-shadow:1px 1px 0 rgba(0,0,0,.9),-1px -1px 0 rgba(0,0,0,.9),1px -1px 0 rgba(0,0,0,.9),-1px 1px 0 rgba(0,0,0,.9);color:#fff;line-height:1;pointer-events:none;-webkit-user-select:none;user-select:none}.piece-side-0,.piece-side-1{color:#fff}.piece-side-2,.piece-side-3{color:#1a1a1a;text-shadow:1px 1px 0 rgba(255,255,255,.5),-1px -1px 0 rgba(255,255,255,.5),1px -1px 0 rgba(255,255,255,.5),-1px 1px 0 rgba(255,255,255,.5)!important}.piece-side-4{color:#fff}.piece-side-5{color:#1a1a1a;text-shadow:1px 1px 0 rgba(255,255,255,.5),-1px -1px 0 rgba(255,255,255,.5),1px -1px 0 rgba(255,255,255,.5),-1px 1px 0 rgba(255,255,255,.5)!important}.piece-side-6{color:#fff}.piece-side-7{color:#1a1a1a;text-shadow:1px 1px 0 rgba(255,255,255,.5),-1px -1px 0 rgba(255,255,255,.5),1px -1px 0 rgba(255,255,255,.5),-1px 1px 0 rgba(255,255,255,.5)!important}.piece-side-8{color:#fff}.piece-side-9{color:#1a1a1a;text-shadow:1px 1px 0 rgba(255,255,255,.5),-1px -1px 0 rgba(255,255,255,.5),1px -1px 0 rgba(255,255,255,.5),-1px 1px 0 rgba(255,255,255,.5)!important}.scores-panel{background:var(--bg-secondary);padding:12px;border-radius:var(--radius-md);width:200px;min-width:180px;flex-shrink:0;max-height:calc(100vh - 80px);overflow-y:auto;border:1px solid rgba(255,255,255,.1)}.scores-panel h3{margin:0 0 15px;color:#fff;font-size:16px;text-transform:uppercase;letter-spacing:1px}.current-turn{margin-bottom:15px;padding:10px;background:#ffffff26;border-radius:var(--radius-sm);border:2px solid var(--accent)}.turn-label{font-weight:700;margin-right:10px}.active-sides{display:inline-flex;gap:8px}.active-side{font-size:1.2em;padding:2px 6px;background:var(--bg-primary);border-radius:4px}.your-turn{display:block;margin-top:5px;color:var(--accent);font-weight:700;animation:pulse 1.5s infinite}.scores-panel .scores-list{display:flex;flex-direction:column;gap:10px}.scores-panel .score-item{display:flex;justify-content:space-between;padding:8px 12px;border-radius:var(--radius-sm);background:#ffffff1a;transition:background-color .3s ease,border-color .3s ease,box-shadow .3s ease}.scores-panel .score-item.active-turn{background:#fff3;border:1px solid var(--accent);box-shadow:0 0 10px #fff3}.scores-panel .score-item.has-active-fields{background:#4ade801f;box-shadow:inset 0 0 8px #4ade8033}.scores-panel .score-item.side-0{border-left:4px solid #FF4444}.scores-panel .score-item.side-1{border-left:4px solid #4488FF}.scores-panel .score-item.side-2{border-left:4px solid #44DD44}.scores-panel .score-item.side-3{border-left:4px solid #FFFF00}.scores-panel .score-item.side-4{border-left:4px solid #DD66FF}.scores-panel .score-item.side-5{border-left:4px solid #FF8844}.scores-panel .score-item.side-6{border-left:4px solid #FF66AA}.scores-panel .score-item.side-7{border-left:4px solid #44DDDD}.scores-panel .score-item.side-8{border-left:4px solid #AA6644}.scores-panel .score-item.side-9{border-left:4px solid var(--side-9)}.scores-panel .score-item.highlighted{background:#ffffff4d;border:2px solid #ffffff;box-shadow:0 0 15px #fff9;transform:scale(1.05)}.score-side{font-weight:700}.scores-panel .score-item.side-0 .score-side{color:#f66}.scores-panel .score-item.side-1 .score-side{color:#6af}.scores-panel .score-item.side-2 .score-side{color:#6f6}.scores-panel .score-item.side-3 .score-side{color:#ff6}.scores-panel .score-item.side-4 .score-side{color:#e8f}.scores-panel .score-item.side-5 .score-side{color:#fa6}.scores-panel .score-item.side-6 .score-side{color:#f8b}.scores-panel .score-item.side-7 .score-side{color:#6ee}.scores-panel .score-item.side-8 .score-side{color:#c86}.scores-panel .score-item.side-9 .score-side{color:var(--side-9)}.scores-panel .score-value{font-size:18px;font-weight:700;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.3)}.board-cell.capture-animation{animation:capture-effect 1s ease}@keyframes capture-effect{0%{transform:scale(1)}50%{transform:scale(1.3);background-color:#fffc}to{transform:scale(1)}}.board-cell.highlighted-territory{box-shadow:0 0 25px #fff,inset 0 0 20px #ffffff80;border:3px solid #ffffff!important;animation:territory-glow 1.5s ease-in-out infinite;z-index:5}@keyframes territory-glow{0%,to{box-shadow:0 0 25px #fff,inset 0 0 20px #ffffff80}50%{box-shadow:0 0 40px #fff,inset 0 0 30px #ffffffb3}}@keyframes glow-pulse{0%,to{text-shadow:0 0 5px currentColor}50%{text-shadow:0 0 20px currentColor}}@media(min-width:1440px){.game-board-container{padding:16px 24px}.board-with-coordinates{--available-width: calc(100vw - 360px) ;--available-height: calc(100vh - 160px) ;--coord-size: 26px}.scores-panel{width:240px;min-width:220px}.game-content{gap:30px}}@media(min-width:1920px){.game-board-container{padding:20px 40px}.board-with-coordinates{--available-width: calc(100vw - 420px) ;--available-height: calc(100vh - 180px) ;--coord-size: 28px}.scores-panel{width:280px;min-width:260px;padding:16px}.scores-panel .score-value{font-size:20px}.game-content{gap:40px}}@media(min-width:2560px){.game-board-container{padding:30px 60px}.board-with-coordinates{--available-width: calc(100vw - 500px) ;--available-height: calc(100vh - 200px) ;--coord-size: 32px}.scores-panel{width:320px;min-width:300px;padding:20px}.scores-panel h3{font-size:20px}.scores-panel .score-value{font-size:24px}.info-value{font-size:20px}.game-content{gap:60px}}@media(max-width:1024px){.game-content{flex-direction:column;align-items:center}.scores-panel{width:100%;max-width:600px;order:1;max-height:200px}.scores-panel .scores-list{flex-direction:row;flex-wrap:wrap;justify-content:center;gap:8px}.scores-panel .score-item{flex:0 0 auto;min-width:90px}.board-with-coordinates{--available-width: calc(100vw - 40px) ;--available-height: calc(100vh - 340px) ;--coord-size: 22px}}@media(max-width:768px){.game-info-header{min-height:auto;flex-wrap:wrap;gap:8px;padding:6px 10px}.info-items{gap:12px;flex-wrap:wrap}.info-label{font-size:12px}.info-value{font-size:14px}.header-btn{padding:5px 10px;font-size:12px;min-width:60px;height:30px}.scores-panel{padding:12px}.scores-panel h3{font-size:14px;margin-bottom:10px}.scores-panel .score-item{padding:5px 8px}.scores-panel .score-value{font-size:14px}.board-with-coordinates{--available-height: calc(100vh - 320px) ;--available-width: calc(100vw - 24px) ;--coord-size: 20px}}@media(max-width:540px){.game-board-container{padding:4px;gap:6px}.game-info-header{padding:5px 8px;min-height:auto}.info-items{gap:8px}.info-label{font-size:11px}.info-value{font-size:13px}.header-btn{padding:4px 8px;font-size:11px;min-width:50px;height:28px}.scores-panel{padding:8px;max-height:150px}.scores-panel h3{font-size:12px;margin-bottom:8px}.scores-panel .score-item{padding:4px 6px;min-width:80px}.scores-panel .score-value{font-size:12px}.board-with-coordinates{--available-height: calc(100vh - 260px) ;--available-width: calc(100vw - 16px) ;--coord-size: 18px;padding:4px}}.game-mode-selector{max-width:900px;margin:0 auto;padding:2rem}.mode-selection{margin-bottom:2rem}.mode-selection h2{text-align:center;margin-bottom:2rem;color:#333;font-size:2rem}.mode-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2rem}.mode-card{background:#fff;border:2px solid #e0e0e0;border-radius:12px;padding:1.5rem;cursor:pointer;transition:all .3s ease;text-align:center}.mode-card:hover{border-color:#4caf50;transform:translateY(-4px);box-shadow:0 8px 16px #0000001a}.mode-card.selected{border-color:#4caf50;background:linear-gradient(135deg,#f0fdf4,#dcfce7);box-shadow:0 8px 16px #4caf5026}.mode-icon{font-size:3rem;margin-bottom:1rem;filter:grayscale(.2)}.mode-card h3{margin:.5rem 0;color:#333;font-size:1.3rem}.mode-card p{margin:.5rem 0;color:#666;font-size:.95rem}.mode-description{font-size:.85rem!important;color:#888!important;line-height:1.4;margin-top:.75rem!important}.ai-configuration{background:#f9f9f9;border-radius:12px;padding:1.5rem;margin-bottom:2rem}.ai-configuration h3{margin-bottom:1.5rem;color:#333}.ai-players-list{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}.ai-player-config{display:flex;justify-content:space-between;align-items:center;background:#fff;padding:1rem;border-radius:8px;border:1px solid #e0e0e0}.player-label{display:flex;align-items:center;gap:.75rem;font-weight:500;color:#333}.side-color{font-size:1.5rem;line-height:1}.side-1{color:#ff6b6b}.side-2{color:#4ecdc4}.side-3{color:#45b7d1}.side-4{color:#ffa07a}.human-badge{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:.4rem 1rem;border-radius:20px;font-size:.9rem;font-weight:500}.difficulty-selector{display:flex;gap:.5rem}.difficulty-btn{padding:.5rem 1rem;background:#fff;border:2px solid #e0e0e0;border-radius:6px;cursor:pointer;transition:all .2s ease;font-size:.9rem;font-weight:500}.difficulty-btn:hover{border-color:#4caf50;background:#f0fdf4}.difficulty-btn.selected{background:#4caf50;color:#fff;border-color:#4caf50}.ai-difficulty-info{background:#f0f4f8;border-left:4px solid #4CAF50;padding:1rem;border-radius:4px}.ai-difficulty-info h4{margin:0 0 .75rem;color:#333;font-size:1rem}.ai-difficulty-info ul{margin:0;padding-left:1.5rem}.ai-difficulty-info li{margin:.5rem 0;color:#666;font-size:.9rem}.ai-difficulty-info strong{color:#333;font-weight:600}.selector-actions{display:flex;justify-content:space-between;gap:1rem;margin-top:2rem}.selector-actions button{padding:.75rem 2rem;font-size:1rem;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease;font-weight:500}.primary-btn{background:linear-gradient(135deg,#4caf50,#45a049);color:#fff}.primary-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #4caf504d}.primary-btn:disabled{opacity:.5;cursor:not-allowed}.secondary-btn{background:#fff;color:#333;border:2px solid #e0e0e0}.secondary-btn:hover{border-color:#999;background:#f9f9f9}@media(max-width:768px){.game-mode-selector{padding:1rem}.mode-cards{grid-template-columns:1fr}.ai-player-config{flex-direction:column;align-items:flex-start;gap:.75rem}.difficulty-selector{flex-wrap:wrap;width:100%}.difficulty-btn{flex:1;min-width:calc(50% - .25rem);text-align:center}.selector-actions{flex-direction:column}.selector-actions button{width:100%}}@media(max-width:480px){.game-mode-selector{padding:.75rem}.mode-selection h2{font-size:1.5rem}.mode-card{padding:1rem}.mode-icon{font-size:2rem;margin-bottom:.5rem}.mode-card h3{font-size:1.1rem}.ai-configuration{padding:1rem}.difficulty-btn{padding:.4rem .6rem;font-size:.8rem}}.lobby-container{max-width:800px;margin:0 auto;padding:var(--spacing-8);min-height:100vh;background:var(--gradient-bg)}.lobby-header{text-align:center;margin-bottom:var(--spacing-10)}.lobby-header h2{font-size:var(--text-4xl);font-weight:var(--font-extrabold);margin-bottom:var(--spacing-4);background:linear-gradient(135deg,#fff,#ccf);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.lobby-header p{color:var(--text-muted);font-size:var(--text-lg);line-height:var(--leading-relaxed)}.lobby-form{background:var(--gradient-card);border-radius:var(--radius-xl);padding:var(--spacing-8);margin-bottom:var(--spacing-8);border:1px solid rgba(255,255,255,.1)}.input-group{margin-bottom:var(--spacing-6)}.input-group label{display:block;margin-bottom:var(--spacing-2);color:var(--text-light);font-weight:var(--font-semibold);font-size:var(--text-lg)}.input-group input{width:100%;padding:var(--spacing-4);border:2px solid rgba(255,255,255,.2);border-radius:var(--radius-lg);font-size:var(--text-lg);transition:var(--transition-fast);background:#ffffff1a;color:var(--text-light)}.input-group input::placeholder{color:#ffffff80}.input-group input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 var(--focus-ring-width) var(--focus-ring-color);transform:translateY(-2px)}.room-id-input{display:flex;gap:var(--spacing-3);align-items:center}.room-id-input input{flex:1}.generate-btn{padding:var(--spacing-4);border:none;background:var(--btn-primary-bg);color:var(--text-light);border-radius:var(--radius-lg);cursor:pointer;font-size:var(--text-xl);transition:var(--transition-normal);min-width:50px}.generate-btn:hover{transform:scale(1.1);box-shadow:var(--btn-primary-shadow)}.generate-btn:focus-visible{outline:none;box-shadow:0 0 0 var(--focus-ring-offset) var(--bg-dark),0 0 0 calc(var(--focus-ring-offset) + var(--focus-ring-width)) var(--focus-ring-color)}.action-buttons{display:flex;gap:var(--spacing-4);justify-content:center;margin-top:var(--spacing-8)}.primary-btn,.secondary-btn{padding:var(--spacing-4) var(--spacing-8);border:none;border-radius:var(--radius-lg);font-size:var(--text-lg);font-weight:var(--font-semibold);cursor:pointer;transition:var(--transition-normal);min-width:150px}.primary-btn{background:var(--btn-primary-bg);color:var(--text-light);box-shadow:var(--btn-primary-shadow)}.primary-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--btn-primary-shadow-hover)}.primary-btn:focus-visible{outline:none;box-shadow:0 0 0 var(--focus-ring-offset) var(--bg-dark),0 0 0 calc(var(--focus-ring-offset) + var(--focus-ring-width)) var(--focus-ring-color)}.secondary-btn{background:transparent;color:var(--text-light);border:2px solid var(--primary)}.secondary-btn:hover:not(:disabled){background:var(--primary);color:var(--text-light);transform:translateY(-2px)}.secondary-btn:focus-visible{outline:none;box-shadow:0 0 0 var(--focus-ring-offset) var(--bg-dark),0 0 0 calc(var(--focus-ring-offset) + var(--focus-ring-width)) var(--focus-ring-color)}.primary-btn:disabled,.secondary-btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.game-info{background:var(--gradient-card);border-radius:var(--radius-xl);padding:var(--spacing-6);margin-top:var(--spacing-8);border-left:4px solid var(--primary)}.game-info h3{color:var(--text-light);margin-bottom:var(--spacing-4);font-size:var(--text-xl);font-weight:var(--font-semibold)}.game-info ul{list-style:none;padding:0}.game-info li{padding:var(--spacing-2) 0;color:var(--text-muted);position:relative;padding-left:var(--spacing-6)}.game-info li:before{content:"🎯";position:absolute;left:0}.room-info{text-align:center;margin-bottom:var(--spacing-8);background:var(--gradient-card);border-radius:var(--radius-xl);padding:var(--spacing-6);border:1px solid rgba(255,255,255,.1)}.room-info h2{color:var(--text-light);font-size:var(--text-3xl);font-weight:var(--font-bold);margin-bottom:var(--spacing-3)}.room-status{display:flex;align-items:center;justify-content:center;gap:var(--spacing-2);color:var(--text-muted);font-size:var(--text-lg)}.status-indicator{font-size:var(--text-xl)}.players-section{margin-bottom:var(--spacing-8)}.players-section h3{color:var(--text-light);font-size:var(--text-2xl);font-weight:var(--font-semibold);margin-bottom:var(--spacing-6);text-align:center}.players-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--spacing-4);margin-bottom:var(--spacing-6)}.player-card{display:flex;align-items:center;gap:var(--spacing-4);padding:var(--spacing-5);background:var(--gradient-card);border-radius:var(--radius-lg);border:2px solid transparent;transition:var(--transition-normal)}.player-card.current-player{border-color:var(--primary);background:linear-gradient(135deg,#f0f3,#80f3);transform:scale(1.02)}.player-card.empty-slot{background:#ffffff0d;border:2px dashed rgba(255,255,255,.3)}.player-avatar{width:50px;height:50px;background:var(--btn-primary-bg);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;color:var(--text-light);font-weight:var(--font-bold);font-size:var(--text-xl)}.player-avatar.empty{background:#ffffff1a;color:var(--text-muted)}.player-info{flex:1}.player-name{font-weight:var(--font-semibold);color:var(--text-light);font-size:var(--text-lg);margin-bottom:var(--spacing-1);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.player-role{color:var(--text-muted);font-size:var(--text-sm)}.player-side{padding:var(--spacing-2) var(--spacing-3);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-light)}.side-1{background:var(--side-0)}.side-2{background:var(--side-1)}.side-3{background:var(--side-2)}.side-4{background:var(--side-3);color:#333}.lobby-actions{text-align:center;margin-bottom:var(--spacing-8)}.start-game-btn.ready{background:var(--btn-info-bg);animation:pulse 2s infinite}@keyframes pulse{0%{box-shadow:0 0 #00ccffb3}70%{box-shadow:0 0 0 10px #0cf0}to{box-shadow:0 0 #0cf0}}.waiting-message{color:var(--text-muted);font-size:var(--text-lg);line-height:var(--leading-relaxed)}.need-players{color:var(--danger);font-weight:var(--font-semibold);margin-top:var(--spacing-3)}.room-sharing{background:var(--gradient-card);border-radius:var(--radius-xl);padding:var(--spacing-6);text-align:center}.room-sharing h4{color:var(--text-light);margin-bottom:var(--spacing-4);font-size:var(--text-xl);font-weight:var(--font-semibold)}.room-id-display{display:flex;align-items:center;justify-content:center;gap:var(--spacing-3);background:#ffffff1a;padding:var(--spacing-4);border-radius:var(--radius-lg);border:1px solid rgba(255,255,255,.1)}.room-id-display code{background:var(--primary);color:var(--text-light);padding:var(--spacing-2) var(--spacing-4);border-radius:var(--radius-md);font-family:var(--font-mono);font-weight:var(--font-bold);font-size:var(--text-lg);letter-spacing:2px}.copy-btn{padding:var(--spacing-2) var(--spacing-3);border:none;background:var(--primary);color:var(--text-light);border-radius:var(--radius-md);cursor:pointer;transition:var(--transition-normal)}.copy-btn:hover{filter:brightness(1.2);transform:scale(1.1)}.copy-btn:focus-visible{outline:none;box-shadow:0 0 0 var(--focus-ring-offset) var(--bg-dark),0 0 0 calc(var(--focus-ring-offset) + var(--focus-ring-width)) var(--focus-ring-color)}@media(max-width:768px){.lobby-container{padding:var(--spacing-4)}.lobby-header h2{font-size:var(--text-3xl)}.lobby-form{padding:var(--spacing-5)}.action-buttons{flex-direction:column}.primary-btn,.secondary-btn{width:100%}.players-list{grid-template-columns:1fr}.room-id-input{flex-direction:column}.room-id-input input,.generate-btn{width:100%}}@media(max-width:480px){.lobby-container{padding:var(--spacing-3)}.lobby-header h2{font-size:var(--text-2xl)}.lobby-header p,.input-group label{font-size:var(--text-base)}.input-group input{padding:var(--spacing-3);font-size:var(--text-base)}.primary-btn,.secondary-btn{padding:var(--spacing-3) var(--spacing-6);font-size:var(--text-base)}.player-card{padding:var(--spacing-4)}.player-avatar{width:40px;height:40px;font-size:var(--text-lg)}.room-id-display{flex-direction:column;gap:var(--spacing-2)}}.main-menu{min-height:100vh;background:var(--gradient-bg);color:var(--text-light);padding:var(--spacing-8);font-family:var(--font-family);position:relative;overflow-y:auto}.menu-header{text-align:center;margin-bottom:3rem}.game-title{font-size:var(--text-6xl);font-weight:var(--font-extrabold);letter-spacing:var(--tracking-wide);margin:0;background:linear-gradient(180deg,#fff,#ccf);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:0 0 40px rgba(255,255,255,.3)}.game-subtitle{font-size:var(--text-lg);color:var(--text-muted);margin-top:var(--spacing-2);letter-spacing:var(--tracking-normal)}.player-name{margin-top:var(--spacing-4);font-size:var(--text-base);color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.click-to-set{color:#fc0;cursor:pointer;text-decoration:underline}.name-input-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:var(--overlay-bg);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal)}.modal-content{background:var(--gradient-card);padding:var(--spacing-8);border-radius:var(--radius-xl);box-shadow:var(--shadow-2xl);min-width:400px;max-width:calc(100vw - var(--spacing-8))}.modal-content h3{margin-top:0;margin-bottom:var(--spacing-6);text-align:center;color:var(--text-light);font-size:var(--text-xl);font-weight:var(--font-semibold)}.modal-content input{width:100%;padding:var(--spacing-3);font-size:var(--text-lg);background:#ffffff1a;border:2px solid rgba(255,255,255,.2);border-radius:var(--radius-md);color:var(--text-light);margin-bottom:var(--spacing-6);transition:var(--transition-fast)}.modal-content input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 var(--focus-ring-width) var(--focus-ring-color)}.modal-content input::placeholder{color:#ffffff80}.modal-content button{width:100%;padding:var(--btn-padding-y) var(--btn-padding-x);font-size:var(--text-lg);font-weight:var(--font-semibold);background:var(--btn-primary-bg);color:var(--text-light);border:none;border-radius:var(--btn-radius);cursor:pointer;transition:var(--transition-normal)}.modal-content button:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--btn-primary-shadow-hover)}.modal-content button:focus-visible{outline:none;box-shadow:0 0 0 var(--focus-ring-offset) var(--bg-dark),0 0 0 calc(var(--focus-ring-offset) + var(--focus-ring-width)) var(--focus-ring-color)}.modal-content button:disabled{opacity:.5;cursor:not-allowed}.menu-section{margin-bottom:var(--spacing-10);max-width:1200px;margin-left:auto;margin-right:auto}.menu-section h2{font-size:var(--text-xl);font-weight:var(--font-semibold);margin-bottom:var(--spacing-4);color:var(--text-muted);text-transform:uppercase;letter-spacing:var(--tracking-wide)}.mode-buttons{display:flex;gap:var(--spacing-4);justify-content:center;flex-wrap:wrap}.mode-btn{flex:1;min-width:200px;max-width:300px;padding:var(--spacing-6);background:#ffffff0d;border:2px solid rgba(255,255,255,.1);border-radius:var(--radius-lg);color:var(--text-light);cursor:pointer;transition:var(--transition-normal);text-align:center}.mode-btn:hover{background:#ffffff1a;border-color:var(--primary-light);transform:translateY(-2px)}.mode-btn:focus-visible{outline:none;box-shadow:0 0 0 var(--focus-ring-offset) var(--bg-dark),0 0 0 calc(var(--focus-ring-offset) + var(--focus-ring-width)) var(--focus-ring-color)}.mode-btn.active{background:linear-gradient(135deg,#ff00ff4d,#8000ff4d);border-color:var(--primary);box-shadow:0 0 20px #ff00ff4d}.mode-icon{font-size:var(--text-3xl);margin-bottom:var(--spacing-2)}.mode-title{font-size:var(--text-lg);font-weight:var(--font-semibold);margin-bottom:var(--spacing-1)}.mode-desc{font-size:var(--text-sm);color:#ffffffb3}.count-buttons{display:flex;gap:var(--spacing-4);justify-content:center;flex-wrap:wrap}.count-btn{padding:var(--spacing-6);min-width:150px;background:#ffffff0d;border:2px solid rgba(255,255,255,.1);border-radius:var(--radius-lg);color:var(--text-light);cursor:pointer;transition:var(--transition-normal);text-align:center}.count-btn:hover{background:#ffffff1a;border-color:var(--primary-light);transform:translateY(-2px)}.count-btn:focus-visible{outline:none;box-shadow:0 0 0 var(--focus-ring-offset) var(--bg-dark),0 0 0 calc(var(--focus-ring-offset) + var(--focus-ring-width)) var(--focus-ring-color)}.count-btn.active{background:linear-gradient(135deg,#ff00ff4d,#8000ff4d);border-color:var(--primary);box-shadow:0 0 20px #ff00ff4d}.count-number{font-size:var(--text-4xl);font-weight:var(--font-bold);margin-bottom:var(--spacing-2)}.count-desc{font-size:var(--text-sm);color:#ffffffb3;line-height:var(--leading-tight)}.difficulty-buttons{display:flex;gap:var(--spacing-4);justify-content:center;flex-wrap:wrap}.diff-btn{padding:var(--spacing-6);min-width:150px;background:#ffffff0d;border:2px solid rgba(255,255,255,.1);border-radius:var(--radius-lg);color:var(--text-light);cursor:pointer;transition:var(--transition-normal);text-align:center;position:relative}.diff-btn:hover:not(:disabled){background:#ffffff1a;transform:translateY(-2px)}.diff-btn:focus-visible{outline:none;box-shadow:0 0 0 var(--focus-ring-offset) var(--bg-dark),0 0 0 calc(var(--focus-ring-offset) + var(--focus-ring-width)) var(--focus-ring-color)}.diff-btn.active{background:linear-gradient(135deg,#ff00ff4d,#8000ff4d);border-color:var(--primary);box-shadow:0 0 20px #ff00ff4d}.diff-btn:nth-child(1):hover{border-color:var(--success)}.diff-btn:nth-child(2):hover{border-color:var(--warning)}.diff-btn:nth-child(3):hover{border-color:var(--secondary)}.diff-btn.nightmare:hover{border-color:var(--danger)}.diff-btn:disabled{opacity:.5;cursor:not-allowed}.diff-title{font-size:var(--text-xl);font-weight:var(--font-semibold);margin-bottom:var(--spacing-1)}.diff-desc{font-size:var(--text-sm);color:#ffffffb3}.coming-soon{position:absolute;top:calc(-1 * var(--spacing-2));right:calc(-1 * var(--spacing-2));background:var(--danger);color:var(--text-light);padding:var(--spacing-1) var(--spacing-2);border-radius:var(--radius-sm);font-size:var(--text-xs);font-weight:var(--font-bold)}.menu-actions{display:flex;gap:var(--spacing-4);justify-content:center;margin:var(--spacing-12) auto;max-width:800px}.action-btn{flex:1;padding:var(--spacing-6) var(--spacing-8);font-size:var(--text-xl);font-weight:var(--font-semibold);border:none;border-radius:var(--radius-lg);color:var(--text-light);cursor:pointer;transition:var(--transition-normal);text-align:center;position:relative}.action-btn:focus-visible{outline:none;box-shadow:0 0 0 var(--focus-ring-offset) var(--bg-dark),0 0 0 calc(var(--focus-ring-offset) + var(--focus-ring-width)) var(--focus-ring-color)}.start-btn{background:var(--btn-primary-bg);box-shadow:var(--btn-primary-shadow)}.start-btn:hover{transform:translateY(-3px);box-shadow:var(--btn-primary-shadow-hover)}.load-btn{background:var(--btn-info-bg);box-shadow:var(--btn-info-shadow)}.load-btn:hover:not(:disabled){transform:translateY(-3px);box-shadow:var(--btn-info-shadow-hover)}.tutorial-btn{background:linear-gradient(135deg,#7c3aed,#4f46e5);box-shadow:0 4px 20px #7c3aed66}.tutorial-btn:hover{transform:translateY(-3px);box-shadow:0 8px 28px #7c3aed8c}.btn-subtitle{display:block;font-size:var(--text-sm);font-weight:var(--font-normal);margin-top:var(--spacing-1);opacity:.9}.menu-footer{display:flex;gap:var(--spacing-4);justify-content:center;margin-top:var(--spacing-12);padding-top:var(--spacing-8);border-top:1px solid rgba(255,255,255,.1)}.footer-btn{padding:var(--spacing-3) var(--spacing-6);background:#ffffff0d;border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-md);color:#fffc;cursor:pointer;transition:var(--transition-normal);font-size:var(--text-base)}.footer-btn:hover{background:#ffffff1a;color:var(--text-light);border-color:#fff6}.footer-btn:focus-visible{outline:none;box-shadow:0 0 0 var(--focus-ring-offset) var(--bg-dark),0 0 0 calc(var(--focus-ring-offset) + var(--focus-ring-width)) var(--focus-ring-color)}.test-mechanics-btn{background:linear-gradient(135deg,#00d4ff33,#0f83);border-color:#00d4ff80;color:#00d4ff}.test-mechanics-btn:hover{background:linear-gradient(135deg,#00d4ff4d,#00ff884d);border-color:#00d4ff;color:#fff;box-shadow:0 0 15px #00d4ff4d}.version-info{position:fixed;bottom:var(--spacing-8);right:var(--spacing-8);text-align:right;z-index:var(--z-sticky)}.version-badge{background:#ff0000e6;color:var(--text-light);padding:var(--spacing-3) var(--spacing-4);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:var(--font-semibold);box-shadow:var(--shadow-lg)}.version-date{font-size:var(--text-xs);opacity:.9;margin-top:var(--spacing-1)}.version-warning{font-size:var(--text-xs);color:var(--warning);margin-top:var(--spacing-1);animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@media(max-width:768px){.main-menu{padding:var(--spacing-6)}.game-title{font-size:var(--text-4xl)}.game-subtitle{font-size:var(--text-base)}.mode-buttons,.count-buttons,.difficulty-buttons{flex-direction:column;align-items:center}.mode-btn,.count-btn,.diff-btn{width:100%;max-width:300px}.menu-actions{flex-direction:column;padding:0 var(--spacing-4)}.action-btn{padding:var(--spacing-5) var(--spacing-6);font-size:var(--text-lg)}.menu-footer{flex-wrap:wrap;gap:var(--spacing-2)}.footer-btn{padding:var(--spacing-2) var(--spacing-4);font-size:var(--text-sm)}.version-info{bottom:var(--spacing-4);right:var(--spacing-4)}.modal-content{min-width:auto;width:calc(100% - var(--spacing-8));max-width:400px}}@media(max-width:480px){.main-menu{padding:var(--spacing-4)}.game-title{font-size:var(--text-3xl);letter-spacing:var(--tracking-normal)}.game-subtitle{font-size:var(--text-sm)}.menu-section h2{font-size:var(--text-lg)}.mode-btn,.count-btn,.diff-btn{padding:var(--spacing-4);min-width:auto}.mode-icon{font-size:var(--text-2xl)}.mode-title,.diff-title{font-size:var(--text-base)}.count-number{font-size:var(--text-3xl)}.action-btn{padding:var(--spacing-4) var(--spacing-5);font-size:var(--text-base)}.btn-subtitle{font-size:var(--text-xs)}.menu-footer{gap:var(--spacing-2);padding:0 var(--spacing-2)}.footer-btn{padding:var(--spacing-2) var(--spacing-3);font-size:var(--text-xs);flex:1;min-width:0;text-align:center}.version-info{position:relative;bottom:auto;right:auto;margin-top:var(--spacing-6);text-align:center}}@media(max-width:374px){.game-title{font-size:var(--text-2xl)}.menu-footer{flex-direction:column;align-items:stretch}.footer-btn{width:100%}}:root{--bg-primary: rgb(17, 24, 39);--bg-secondary: rgb(31, 41, 55);--bg-tertiary: rgb(55, 65, 81);--text-primary: rgb(255, 255, 255);--text-secondary: rgb(209, 213, 219);--accent-primary: rgb(147, 51, 234);--accent-secondary: rgb(236, 72, 153);--board-bg: rgb(31, 41, 55);--cell-neutral: rgb(55, 65, 81);--cell-hover: rgb(75, 85, 99);--cell-border: #333;--side-0: #FF0000;--side-1: #0000FF;--side-2: #008000;--side-3: #FFFF00;--side-4: #800080;--side-5: #FFA500;--side-6: #FFC0CB;--side-7: #40E0D0;--side-8: #8B4513;--side-9: #C0C0C0;--side-0-border: #CC0000;--side-1-border: #0000CC;--side-2-border: #006600;--side-3-border: #333333;--side-4-border: #660066;--side-5-border: #CC8400;--side-6-border: #333333;--side-7-border: #30B0A0;--side-8-border: #6B3410;--side-9-border: #7A7A7A;--active-field: #4CAF50;--available-move: #FFEB3B;--selected: #FF9800;--danger-low: rgba(255, 193, 7, .3);--danger-medium: rgba(255, 152, 0, .5);--danger-high: rgba(255, 87, 34, .7);--danger-critical: rgba(244, 67, 54, .9);--success: #4CAF50;--warning: #FFC107;--error: #F44336;--info: #2196F3;--spacing-xs: 2px;--spacing-sm: 4px;--spacing-md: 8px;--spacing-lg: 16px;--spacing-xl: 24px;--spacing-2xl: 32px;--radius-sm: 3px;--radius-md: 8px;--radius-lg: 15px;--shadow-sm: 0 2px 4px rgba(0, 0, 0, .1);--shadow-md: 0 4px 15px rgba(0, 0, 0, .2);--shadow-lg: 0 10px 30px rgba(0, 0, 0, .3);--shadow-glow: 0 0 20px;--transition-fast: .2s ease;--transition-normal: .3s ease;--transition-slow: .5s ease;--z-base: 1;--z-hover: 10;--z-selected: 20;--z-dropdown: 100;--z-sticky: 200;--z-overlay: 500;--z-modal: 1000;--z-popover: 1500;--z-toast: 2000;--font-sans: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-mono: "SF Mono", "Fira Code", "Fira Mono", Consolas, monospace;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--text-4xl: 2.25rem;--text-5xl: 3rem;--text-6xl: 4rem;--font-normal: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--font-extrabold: 800;--leading-none: 1;--leading-tight: 1.25;--leading-snug: 1.375;--leading-normal: 1.5;--leading-relaxed: 1.625;--leading-loose: 2;--tracking-tighter: -.05em;--tracking-tight: -.025em;--tracking-normal: 0;--tracking-wide: .025em;--tracking-wider: .05em;--tracking-widest: .1em;--btn-padding-y: .75rem;--btn-padding-x: 1.5rem;--btn-padding-y-sm: .5rem;--btn-padding-x-sm: 1rem;--btn-padding-y-lg: 1rem;--btn-padding-x-lg: 2rem;--btn-radius: var(--radius-md);--btn-font-weight: var(--font-semibold);--btn-transition: all var(--transition-fast);--btn-primary-bg: linear-gradient(135deg, #ff00ff 0%, #8800ff 100%);--btn-primary-hover: linear-gradient(135deg, #ff33ff 0%, #aa33ff 100%);--btn-primary-shadow: 0 10px 30px rgba(255, 0, 255, .3);--btn-primary-shadow-hover: 0 15px 40px rgba(255, 0, 255, .4);--btn-secondary-bg: transparent;--btn-secondary-border: rgba(255, 255, 255, .3);--btn-danger-bg: linear-gradient(135deg, #f44336 0%, #e91e63 100%);--btn-success-bg: linear-gradient(135deg, #4caf50 0%, #8bc34a 100%);--btn-info-bg: linear-gradient(135deg, #00ccff 0%, #0088ff 100%);--btn-info-shadow: 0 10px 30px rgba(0, 204, 255, .3);--btn-info-shadow-hover: 0 15px 40px rgba(0, 204, 255, .4);--focus-ring-color: rgba(147, 51, 234, .5);--focus-ring-width: 3px;--focus-ring-offset: 2px;--spacing-0: 0;--spacing-1: .25rem;--spacing-2: .5rem;--spacing-3: .75rem;--spacing-4: 1rem;--spacing-5: 1.25rem;--spacing-6: 1.5rem;--spacing-7: 1.75rem;--spacing-8: 2rem;--spacing-9: 2.25rem;--spacing-10: 2.5rem;--spacing-11: 2.75rem;--spacing-12: 3rem;--spacing-14: 3.5rem;--spacing-16: 4rem;--spacing-20: 5rem;--spacing-24: 6rem;--radius-none: 0;--radius-xs: 2px;--radius-xl: 16px;--radius-2xl: 24px;--radius-full: 9999px;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .05);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, .25);--primary: #ff00ff;--primary-light: rgba(255, 0, 255, .5);--secondary: #ff6600;--danger: #ff0000;--text-light: #ffffff;--text-muted: #ccccff;--bg-dark: #1a0033;--overlay-bg: rgba(0, 0, 0, .8);--gradient-bg: linear-gradient(135deg, #1a0033 0%, #330066 50%, #4d0099 100%);--gradient-card: linear-gradient(135deg, #2a0052 0%, #440088 100%);--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif}@keyframes glow-pulse{0%,to{box-shadow:0 0 5px var(--accent-primary),0 0 10px var(--accent-primary)}50%{box-shadow:0 0 20px var(--accent-primary),0 0 30px var(--accent-primary)}}@keyframes knight-move{0%{transform:translate(0)}25%{transform:translate(-10px,-20px) rotate(-5deg)}50%{transform:translate(10px,-30px) rotate(5deg)}75%{transform:translate(-5px,-10px) rotate(-3deg)}to{transform:translate(0) rotate(0)}}@keyframes capture-effect{0%{transform:scale(1);opacity:1}50%{transform:scale(1.5);opacity:.5}to{transform:scale(2);opacity:0}}@keyframes bounce-in{0%{transform:scale(.3);opacity:0}50%{transform:scale(1.05)}70%{transform:scale(.9)}to{transform:scale(1);opacity:1}}@keyframes slide-in{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes danger-pulse{0%,to{box-shadow:inset 0 0 20px var(--danger-critical)}50%{box-shadow:inset 0 0 30px var(--danger-critical)}}.game-board{background:var(--board-bg);border-radius:var(--radius-md);padding:var(--spacing-lg);box-shadow:var(--shadow-md);border:2px solid var(--cell-border)}.board-cell{width:clamp(35px,8vw,60px);height:clamp(35px,8vw,60px);border:2px solid var(--cell-border);display:flex;align-items:center;justify-content:center;position:relative;cursor:pointer;transition:all var(--transition-normal);background:var(--cell-neutral);border-radius:var(--radius-sm);font-size:clamp(14px,3vw,24px);font-weight:700}.board-cell:hover{border-color:var(--active-field);transform:scale(1.08);z-index:var(--z-hover);box-shadow:0 4px 12px #4caf504d}.board-cell.side-0{background-color:var(--side-0)!important;border-color:var(--side-0-border)!important}.board-cell.side-1{background-color:var(--side-1)!important;border-color:var(--side-1-border)!important}.board-cell.side-2{background-color:var(--side-2)!important;border-color:var(--side-2-border)!important}.board-cell.side-3{background-color:var(--side-3)!important;border-color:var(--side-3-border)!important;border-width:3px!important}.board-cell.side-4{background-color:var(--side-4)!important;border-color:var(--side-4-border)!important}.board-cell.side-5{background-color:var(--side-5)!important;border-color:var(--side-5-border)!important}.board-cell.side-6{background-color:var(--side-6)!important;border-color:var(--side-6-border)!important;border-width:3px!important}.board-cell.side-7{background-color:var(--side-7)!important;border-color:var(--side-7-border)!important}.board-cell.side-8{background-color:var(--side-8)!important;border-color:var(--side-8-border)!important}.board-cell.side-9{background-color:var(--side-9)!important;border-color:var(--side-9-border)!important;border-width:3px!important}.piece{font-size:44px;font-weight:700;text-shadow:0 0 3px rgba(255,255,255,1),0 0 6px rgba(255,255,255,.9),2px 2px 4px rgba(0,0,0,1),-1px -1px 4px rgba(0,0,0,.8);filter:drop-shadow(0 0 2px rgba(255,255,255,.9));color:#fff;animation:pulse 2s ease-in-out infinite}.piece-side-3,.piece-side-6,.piece-side-7,.piece-side-9{color:#000;text-shadow:0 0 3px rgba(255,255,255,1),1px 1px 2px rgba(255,255,255,.8);-webkit-text-stroke:1px rgba(255,255,255,.8)}.active-field{border:3px solid var(--active-field)!important;box-shadow:0 0 15px #4caf50cc,inset 0 0 10px #4caf5033;animation:glow-pulse 1.5s infinite}.available-move{border:2px solid var(--available-move)!important;background:#ffeb3b33!important;cursor:pointer}.available-move:hover{background:#ffeb3b66!important;transform:scale(1.1)}.selected{border:3px solid var(--selected)!important;background:#ff98004d!important;box-shadow:0 0 20px #ff9800cc;animation:pulse 1s infinite}.danger-low{box-shadow:inset 0 0 10px var(--danger-low)}.danger-medium{box-shadow:inset 0 0 15px var(--danger-medium)}.danger-high{box-shadow:inset 0 0 20px var(--danger-high);animation:danger-pulse 1s infinite}.danger-critical{box-shadow:inset 0 0 25px var(--danger-critical);animation:danger-pulse .5s infinite}.button{background:var(--accent-primary);color:var(--text-primary);border:none;padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);font-weight:700}.button:hover{background:var(--accent-secondary);transform:translateY(-2px);box-shadow:var(--shadow-md)}.modal{background:var(--bg-secondary);border-radius:var(--radius-lg);padding:var(--spacing-2xl);box-shadow:var(--shadow-lg);color:var(--text-primary);animation:slide-in .3s ease}.overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:var(--z-overlay);animation:fade-in .3s ease}[data-theme=dark]{--bg-primary: rgb(0, 0, 0);--bg-secondary: rgb(23, 23, 23);--bg-tertiary: rgb(38, 38, 38);--text-primary: rgb(245, 245, 245);--text-secondary: rgb(163, 163, 163);--board-bg: rgb(23, 23, 23);--cell-neutral: rgb(38, 38, 38);--cell-hover: rgb(64, 64, 64)}[data-theme=neon]{--bg-primary: rgb(13, 13, 23);--bg-secondary: rgb(23, 23, 43);--bg-tertiary: rgb(33, 33, 63);--accent-primary: rgb(0, 255, 255);--accent-secondary: rgb(255, 0, 255);--board-bg: rgb(23, 23, 43);--cell-neutral: rgb(33, 33, 63)}[data-theme=neon] .game-board{box-shadow:0 0 50px #00ffff4d,inset 0 0 50px #ff00ff1a}[data-theme=neon] .piece{filter:drop-shadow(0 0 10px currentColor)}[data-theme=forest]{--bg-primary: rgb(28, 39, 33);--bg-secondary: rgb(38, 52, 44);--bg-tertiary: rgb(48, 65, 55);--text-primary: rgb(240, 253, 244);--text-secondary: rgb(187, 247, 208);--accent-primary: rgb(34, 197, 94);--accent-secondary: rgb(251, 146, 60);--board-bg: rgb(38, 52, 44);--cell-neutral: rgb(48, 65, 55)}[data-theme=forest] .board-cell{border-radius:4px}[data-theme=forest] .board-cell:hover{box-shadow:0 2px 8px #22c55e4d}@media(max-width:768px){.board-cell{width:45px;height:45px}.piece{font-size:34px}}@media(max-width:480px){.board-cell{width:38px;height:38px}.piece{font-size:28px}}@media(max-width:374px){.board-cell{width:32px;height:32px;border-width:1px}.piece{font-size:20px}}.text-primary{color:var(--text-primary)}.text-secondary{color:var(--text-secondary)}.bg-primary{background-color:var(--bg-primary)}.bg-secondary{background-color:var(--bg-secondary)}.bg-tertiary{background-color:var(--bg-tertiary)}.shadow-sm{box-shadow:var(--shadow-sm)}.shadow-md{box-shadow:var(--shadow-md)}.shadow-lg{box-shadow:var(--shadow-lg)}.rounded-sm{border-radius:var(--radius-sm)}.rounded-md{border-radius:var(--radius-md)}.rounded-lg{border-radius:var(--radius-lg)}.transition-fast{transition:all var(--transition-fast)}.transition-normal{transition:all var(--transition-normal)}.transition-slow{transition:all var(--transition-slow)}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--btn-padding-y) var(--btn-padding-x);font-family:var(--font-sans);font-size:var(--text-base);font-weight:var(--btn-font-weight);line-height:var(--leading-tight);text-decoration:none;border:2px solid transparent;border-radius:var(--btn-radius);cursor:pointer;transition:var(--btn-transition);-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}.btn:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.btn-primary{background:var(--btn-primary-bg);color:var(--text-primary);border-color:transparent}.btn-primary:hover:not(:disabled){background:var(--btn-primary-hover);transform:translateY(-2px);box-shadow:var(--shadow-md)}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-secondary{background:var(--btn-secondary-bg);color:var(--text-primary);border-color:var(--btn-secondary-border)}.btn-secondary:hover:not(:disabled){background:#ffffff1a;border-color:#ffffff80}.btn-danger{background:var(--btn-danger-bg);color:var(--text-primary)}.btn-danger:hover:not(:disabled){filter:brightness(1.1);transform:translateY(-2px);box-shadow:var(--shadow-md)}.btn-success{background:var(--btn-success-bg);color:var(--text-primary)}.btn-success:hover:not(:disabled){filter:brightness(1.1);transform:translateY(-2px);box-shadow:var(--shadow-md)}.btn-ghost{background:transparent;color:var(--text-secondary);border-color:transparent}.btn-ghost:hover:not(:disabled){background:#ffffff1a;color:var(--text-primary)}.btn-sm{padding:var(--btn-padding-y-sm) var(--btn-padding-x-sm);font-size:var(--text-sm)}.btn-lg{padding:var(--btn-padding-y-lg) var(--btn-padding-x-lg);font-size:var(--text-lg)}.btn-icon{padding:var(--spacing-md);min-width:44px;min-height:44px}.btn-icon-sm{padding:var(--spacing-sm);min-width:36px;min-height:36px}*:focus{outline:none}*:focus-visible{outline:var(--focus-ring-width) solid var(--focus-ring-color);outline-offset:var(--focus-ring-offset)}.btn:focus-visible{outline:var(--focus-ring-width) solid var(--focus-ring-color);outline-offset:var(--focus-ring-offset);box-shadow:0 0 0 calc(var(--focus-ring-width) + var(--focus-ring-offset)) var(--focus-ring-color)}input:focus-visible,textarea:focus-visible,select:focus-visible{outline:var(--focus-ring-width) solid var(--focus-ring-color);outline-offset:0;border-color:var(--accent-primary)}button:focus:not(:focus-visible),a:focus:not(:focus-visible),input:focus:not(:focus-visible){outline:none}@media(forced-colors:active){.btn{border:2px solid currentColor}*:focus-visible{outline:3px solid Highlight;outline-offset:2px}}.text-xs{font-size:var(--text-xs)}.text-sm{font-size:var(--text-sm)}.text-base{font-size:var(--text-base)}.text-lg{font-size:var(--text-lg)}.text-xl{font-size:var(--text-xl)}.text-2xl{font-size:var(--text-2xl)}.text-3xl{font-size:var(--text-3xl)}.text-4xl{font-size:var(--text-4xl)}.text-5xl{font-size:var(--text-5xl)}.font-normal{font-weight:var(--font-normal)}.font-medium{font-weight:var(--font-medium)}.font-semibold{font-weight:var(--font-semibold)}.font-bold{font-weight:var(--font-bold)}.font-extrabold{font-weight:var(--font-extrabold)}.leading-none{line-height:var(--leading-none)}.leading-tight{line-height:var(--leading-tight)}.leading-normal{line-height:var(--leading-normal)}.leading-relaxed{line-height:var(--leading-relaxed)}.gap-xs{gap:var(--spacing-xs)}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.gap-lg{gap:var(--spacing-lg)}.gap-xl{gap:var(--spacing-xl)}.gap-2xl{gap:var(--spacing-2xl)}.p-xs{padding:var(--spacing-xs)}.p-sm{padding:var(--spacing-sm)}.p-md{padding:var(--spacing-md)}.p-lg{padding:var(--spacing-lg)}.p-xl{padding:var(--spacing-xl)}.p-2xl{padding:var(--spacing-2xl)}.m-xs{margin:var(--spacing-xs)}.m-sm{margin:var(--spacing-sm)}.m-md{margin:var(--spacing-md)}.m-lg{margin:var(--spacing-lg)}.m-xl{margin:var(--spacing-xl)}.m-2xl{margin:var(--spacing-2xl)}.flex{display:flex}.flex-col{flex-direction:column}.flex-row{flex-direction:row}.flex-wrap{flex-wrap:wrap}.flex-1{flex:1}.items-center{align-items:center}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.grid{display:grid}.grid-cols-2{grid-template-columns:repeat(2,1fr)}.grid-cols-3{grid-template-columns:repeat(3,1fr)}.grid-cols-4{grid-template-columns:repeat(4,1fr)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:var(--overlay-bg);display:flex;justify-content:center;align-items:center;z-index:var(--z-modal);animation:fadeIn .2s ease-in;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-container{background:var(--gradient-card);border-radius:var(--radius-xl);max-width:700px;max-height:85vh;width:90%;display:flex;flex-direction:column;box-shadow:var(--shadow-2xl);animation:slideUp .3s ease-out;border:2px solid rgba(255,255,255,.1)}@keyframes slideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{padding:var(--spacing-6) var(--spacing-8);border-bottom:2px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center}.modal-header h2{margin:0;color:var(--text-light);font-size:var(--text-3xl);font-weight:var(--font-bold)}.close-btn{background:#ffffff1a;border:none;color:var(--text-light);font-size:var(--text-2xl);width:44px;height:44px;border-radius:var(--radius-full);cursor:pointer;transition:var(--transition-fast);display:flex;align-items:center;justify-content:center}.close-btn:hover{background:#fff3;transform:scale(1.1)}.close-btn:focus-visible{outline:none;box-shadow:0 0 0 var(--focus-ring-width) var(--focus-ring-color)}.modal-content{padding:var(--spacing-8);overflow-y:auto;flex:1}.modal-content::-webkit-scrollbar{width:8px}.modal-content::-webkit-scrollbar-track{background:#ffffff0d}.modal-content::-webkit-scrollbar-thumb{background:#fff3;border-radius:var(--radius-sm)}.modal-footer{padding:var(--spacing-5) var(--spacing-8);border-top:2px solid rgba(255,255,255,.1);display:flex;justify-content:flex-end;gap:var(--spacing-4)}.btn-primary,.btn-secondary,.btn-small{padding:var(--spacing-3) var(--spacing-8);font-size:var(--text-base);font-weight:var(--font-semibold);border:none;border-radius:var(--radius-md);cursor:pointer;transition:var(--transition-fast)}.btn-primary{background:var(--btn-primary-bg);color:var(--text-light)}.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--btn-primary-shadow)}.btn-primary:focus-visible{outline:none;box-shadow:0 0 0 var(--focus-ring-width) var(--focus-ring-color)}.btn-secondary{background:linear-gradient(135deg,#434343,#000);color:var(--text-light)}.btn-secondary:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.btn-secondary:focus-visible{outline:none;box-shadow:0 0 0 var(--focus-ring-width) var(--focus-ring-color)}.btn-small{padding:var(--spacing-2) var(--spacing-4);font-size:var(--text-sm)}.rules-section{margin-bottom:var(--spacing-8)}.rules-section h3{color:var(--warning);font-size:var(--text-xl);font-weight:var(--font-semibold);margin-bottom:var(--spacing-4)}.rules-section p,.rules-section li{color:#ffffffe6;line-height:var(--leading-relaxed);margin-bottom:var(--spacing-3)}.rules-section ul{padding-left:var(--spacing-6)}.rules-section li{margin-bottom:var(--spacing-2)}.rules-section strong{color:var(--text-light);font-weight:var(--font-semibold)}.settings-section{margin-bottom:var(--spacing-8)}.settings-section h3{color:var(--warning);font-size:var(--text-xl);font-weight:var(--font-semibold);margin-bottom:var(--spacing-5);border-bottom:2px solid rgba(255,215,0,.2);padding-bottom:var(--spacing-3)}.setting-item{margin-bottom:var(--spacing-5)}.setting-item.indent{margin-left:var(--spacing-8)}.setting-label{color:#ffffffe6;font-size:var(--text-base);display:flex;align-items:center;gap:var(--spacing-3);margin-bottom:var(--spacing-3);cursor:pointer}.setting-label input[type=checkbox]{width:20px;height:20px;cursor:pointer;accent-color:var(--primary)}.slider-container{display:flex;align-items:center;gap:var(--spacing-4)}.volume-slider{flex:1;height:6px;background:#ffffff1a;border-radius:var(--radius-sm);outline:none;-webkit-appearance:none}.volume-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;background:var(--primary);cursor:pointer;border-radius:var(--radius-full)}.volume-slider::-moz-range-thumb{width:18px;height:18px;background:var(--primary);cursor:pointer;border-radius:var(--radius-full);border:none}.volume-slider:focus-visible{outline:none;box-shadow:0 0 0 var(--focus-ring-width) var(--focus-ring-color)}.volume-value{color:var(--text-light);font-weight:var(--font-semibold);min-width:45px}.button-group{display:flex;gap:var(--spacing-3)}.option-btn{flex:1;padding:var(--spacing-3) var(--spacing-5);background:#ffffff0d;border:2px solid rgba(255,255,255,.1);color:#ffffffb3;border-radius:var(--radius-md);cursor:pointer;transition:var(--transition-fast);font-weight:var(--font-semibold)}.option-btn:hover{background:#ffffff1a;border-color:#fff3}.option-btn:focus-visible{outline:none;box-shadow:0 0 0 var(--focus-ring-width) var(--focus-ring-color)}.option-btn.active{background:var(--btn-primary-bg);border-color:var(--primary);color:var(--text-light)}.setting-description{color:#fff9;font-size:var(--text-sm);margin-top:var(--spacing-1);margin-left:var(--spacing-8)}.profile-section{margin-bottom:var(--spacing-8)}.profile-section h3{color:var(--warning);font-size:var(--text-xl);font-weight:var(--font-semibold);margin-bottom:var(--spacing-4)}.profile-avatar{display:flex;justify-content:center;margin-bottom:var(--spacing-5)}.avatar-placeholder{width:120px;height:120px;border-radius:var(--radius-full);background:var(--btn-primary-bg);display:flex;align-items:center;justify-content:center;font-size:var(--text-5xl);color:var(--text-light);font-weight:var(--font-bold)}.profile-info{text-align:center}.name-display{display:flex;align-items:center;justify-content:center;gap:var(--spacing-4)}.player-name-text{color:var(--text-light);font-size:var(--text-2xl);font-weight:var(--font-semibold)}.edit-btn{padding:var(--spacing-2) var(--spacing-4);background:#ffffff1a;border:none;color:var(--text-light);border-radius:var(--radius-md);cursor:pointer;transition:var(--transition-fast)}.edit-btn:hover{background:#fff3}.edit-btn:focus-visible{outline:none;box-shadow:0 0 0 var(--focus-ring-width) var(--focus-ring-color)}.name-edit{display:flex;flex-direction:column;gap:var(--spacing-3);align-items:center}.name-edit input{width:100%;max-width:300px;padding:var(--spacing-3);font-size:var(--text-lg);background:#ffffff0d;border:2px solid rgba(255,255,255,.2);color:var(--text-light);border-radius:var(--radius-md);text-align:center}.name-edit input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 var(--focus-ring-width) var(--focus-ring-color)}.edit-actions{display:flex;gap:var(--spacing-3)}.info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-4)}.info-item{background:#ffffff0d;padding:var(--spacing-4);border-radius:var(--radius-md)}.info-label{color:#fff9;font-size:var(--text-sm);display:block;margin-bottom:var(--spacing-1)}.info-value{color:var(--text-light);font-size:var(--text-lg);font-weight:var(--font-semibold)}.achievements-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:var(--spacing-4)}.achievement{background:#ffffff0d;padding:var(--spacing-5);border-radius:var(--radius-md);text-align:center;transition:var(--transition-fast)}.achievement.locked{opacity:.4;filter:grayscale(100%)}.achievement-icon{font-size:var(--text-4xl);margin-bottom:var(--spacing-3)}.achievement-name{color:var(--text-light);font-size:var(--text-sm);font-weight:var(--font-semibold)}.stats-section{margin-bottom:var(--spacing-8)}.stats-section h3{color:var(--warning);font-size:var(--text-xl);font-weight:var(--font-semibold);margin-bottom:var(--spacing-5)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:var(--spacing-4)}.stat-card{background:#ffffff0d;padding:var(--spacing-5);border-radius:var(--radius-md);text-align:center}.stat-value{font-size:var(--text-3xl);font-weight:var(--font-bold);color:var(--primary);margin-bottom:var(--spacing-1)}.stat-label{color:#ffffffb3;font-size:var(--text-sm)}.streak-info{display:flex;gap:var(--spacing-5)}.streak-item{flex:1;background:#ffffff0d;padding:var(--spacing-5);border-radius:var(--radius-md);display:flex;align-items:center;gap:var(--spacing-4)}.streak-icon{font-size:var(--text-4xl)}.streak-label{color:#ffffffb3;font-size:var(--text-sm);margin-bottom:var(--spacing-1)}.streak-value{color:var(--text-light);font-size:var(--text-xl);font-weight:var(--font-bold)}.side-stats-table{background:#ffffff0d;border-radius:var(--radius-md);overflow:hidden}.table-header,.table-row{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:var(--spacing-4);padding:var(--spacing-4) var(--spacing-5)}.table-header{background:#ffffff1a;color:var(--warning);font-weight:var(--font-bold);border-bottom:2px solid rgba(255,215,0,.2)}.table-row{border-bottom:1px solid rgba(255,255,255,.05);color:#ffffffe6}.table-row:last-child{border-bottom:none}.side-info{display:flex;align-items:center;gap:var(--spacing-3)}.side-color-dot{width:16px;height:16px;border-radius:var(--radius-full);border:2px solid rgba(255,255,255,.3)}.time-stats{background:#ffffff0d;padding:var(--spacing-5);border-radius:var(--radius-md)}.time-item{display:flex;justify-content:space-between;padding:var(--spacing-3) 0;border-bottom:1px solid rgba(255,255,255,.05)}.time-item:last-child{border-bottom:none}.time-label{color:#ffffffb3}.time-value{color:var(--text-light);font-weight:var(--font-semibold)}.no-stats-message{text-align:center;padding:var(--spacing-10) var(--spacing-5);color:#fff9}.no-stats-message p{margin:var(--spacing-3) 0;font-size:var(--text-lg)}@media(max-width:768px){.modal-container{width:95%;max-height:90vh}.modal-header{padding:var(--spacing-4) var(--spacing-5)}.modal-header h2{font-size:var(--text-2xl)}.modal-content{padding:var(--spacing-5)}.modal-footer{padding:var(--spacing-4) var(--spacing-5)}.stats-grid,.achievements-grid{grid-template-columns:repeat(2,1fr)}.info-grid{grid-template-columns:1fr}.streak-info{flex-direction:column}.table-header,.table-row{grid-template-columns:2fr 1fr 1fr}.table-row span:last-child{display:none}.button-group{flex-wrap:wrap}.option-btn{min-width:calc(50% - var(--spacing-2))}}@media(max-width:480px){.modal-header h2{font-size:var(--text-xl)}.close-btn{width:36px;height:36px;font-size:var(--text-xl)}.stats-grid,.achievements-grid{grid-template-columns:1fr}.avatar-placeholder{width:100px;height:100px;font-size:var(--text-4xl)}.player-name-text{font-size:var(--text-xl)}.stat-value{font-size:var(--text-2xl)}}.tutorial-modal{max-width:760px;max-height:88vh}.tut-progress{display:flex;gap:8px;justify-content:center;padding:12px 32px;border-bottom:2px solid rgba(255,255,255,.08);flex-wrap:wrap}.tut-progress-dot{width:10px;height:10px;border-radius:50%;background:#fff3;border:none;cursor:pointer;transition:background .2s,transform .2s;padding:0}.tut-progress-dot:hover{background:#fff6;transform:scale(1.3)}.tut-progress-dot.done{background:#4ade8099}.tut-progress-dot.active{background:#60a5fa;transform:scale(1.4)}.tut-content{font-size:.95rem;color:#ffffffe6}.tut-section{display:flex;flex-direction:column;gap:16px}.tut-lead{font-size:1.05rem;line-height:1.65;margin:0}.tut-goal-box{display:flex;align-items:flex-start;gap:14px;background:#60a5fa1a;border:1px solid rgba(96,165,250,.3);border-radius:10px;padding:16px 20px;line-height:1.6}.tut-goal-icon{font-size:2rem;flex-shrink:0}.tut-fact-grid{display:flex;gap:12px;flex-wrap:wrap}.tut-fact{flex:1;min-width:80px;background:#ffffff0f;border-radius:10px;padding:14px;text-align:center;display:flex;flex-direction:column;gap:4px}.tut-fact-num{font-size:1.8rem;font-weight:700;color:#60a5fa}.tut-fact-desc{font-size:.8rem;color:#fff9}.tut-side-colors{display:flex;flex-wrap:wrap;gap:8px}.tut-side-chip{display:flex;align-items:center;gap:6px;background:#ffffff12;border-radius:20px;padding:4px 10px;font-size:.82rem}.tut-side-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0;border:1px solid rgba(255,255,255,.3)}.tut-starting-grid{display:flex;gap:16px;flex-wrap:wrap;align-items:flex-start}.tut-starting-table{flex:1;min-width:200px;background:#ffffff0a;border-radius:10px;overflow:hidden;font-size:.85rem}.tut-st-header,.tut-st-row{display:grid;grid-template-columns:40px 80px 1fr;gap:8px;padding:7px 12px;align-items:center}.tut-st-header{background:#60a5fa26;font-weight:600;color:#93c5fd}.tut-st-row:nth-child(2n){background:#ffffff08}.tut-st-id{font-weight:700;color:#60a5fa}.tut-st-pos{color:#ffffff8c;font-size:.78rem}.tut-board-legend{flex:1;min-width:180px;display:flex;flex-direction:column;gap:10px}.tut-legend-row{display:flex;flex-direction:column;gap:8px}.tut-legend-item{display:flex;align-items:center;gap:8px;font-size:.85rem}.tut-legend-label{color:#fffc}.tut-board{display:flex;flex-direction:column;gap:2px;flex-shrink:0}.tut-board-row{display:flex;gap:2px;align-items:center}.tut-board-col-labels{display:flex;gap:2px;margin-bottom:2px}.tut-board-corner{width:16px;flex-shrink:0}.tut-board-label{width:22px;height:16px;font-size:.65rem;color:#fff6;text-align:center;display:flex;align-items:center;justify-content:center}.tut-board-row-num{width:16px;flex-shrink:0}.tut-cell{display:inline-block;width:22px;height:22px;border-radius:3px;border:1px solid rgba(255,255,255,.1);flex-shrink:0}.tut-cell--neutral{background:#ffffff14}.tut-cell--owned-blue{background:#1d4ed8}.tut-cell--owned-red{background:#b91c1c}.tut-cell--piece-blue{background:#3b82f6;border:2px solid #93c5fd}.tut-cell--piece-red{background:#ef4444;border:2px solid #fca5a5}.tut-cell--move-target{background:#4ade8059;border:2px solid #4ade80}.tut-cell--burned{background:repeating-linear-gradient(45deg,#3f3f3f,#3f3f3f 4px,#1f1f1f 4px,#1f1f1f 8px)}.tut-diagram-row{display:flex;gap:24px;align-items:flex-start;flex-wrap:wrap}.tut-diagram-desc{flex:1;min-width:160px;font-size:.9rem;line-height:1.6}.tut-diagram-desc p{margin:0 0 8px}.tut-chip{display:inline-block;padding:1px 7px;border-radius:12px;font-size:.82rem;font-weight:600}.tut-chip--blue{background:#3b82f64d;color:#93c5fd}.tut-chip--red{background:#ef44444d;color:#fca5a5}.tut-chip--green{background:#4ade804d;color:#86efac}.tut-callout{border-radius:10px;padding:12px 16px;font-size:.88rem;line-height:1.6}.tut-callout--info{background:#60a5fa1a;border-left:4px solid #60a5fa}.tut-callout--warn{background:#fbbf241a;border-left:4px solid #fbbf24}.tut-callout--success{background:#4ade801a;border-left:4px solid #4ade80}.tut-rounds-table{background:#ffffff0a;border-radius:10px;overflow:hidden;font-size:.88rem}.tut-rt-header,.tut-rt-row{display:grid;grid-template-columns:120px 1fr;gap:16px;padding:10px 16px;align-items:center}.tut-rt-header{background:#60a5fa26;font-weight:600;color:#93c5fd}.tut-rt-row:nth-child(2n){background:#ffffff08}.tut-rt-row--highlight{background:#fbbf2412!important}.tut-capture-cards{display:flex;gap:12px;flex-wrap:wrap}.tut-capture-card{flex:1;min-width:180px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:14px;font-size:.88rem;line-height:1.55}.tut-capture-card-title{font-weight:700;color:#fbbf24;margin-bottom:6px}.tut-trap-cards{display:flex;flex-direction:column;gap:10px}.tut-trap-card{border-radius:10px;padding:12px 16px;font-size:.88rem;line-height:1.55}.tut-trap-card p{margin:4px 0 0}.tut-trap-card--escape{background:#4ade8014;border-left:4px solid #4ade80}.tut-trap-card--force{background:#fbbf2414;border-left:4px solid #fbbf24}.tut-trap-card--single{background:#ef444414;border-left:4px solid #ef4444}.tut-trap-type{font-weight:700;margin-bottom:4px}.tut-trap-card--escape .tut-trap-type{color:#4ade80}.tut-trap-card--force .tut-trap-type{color:#fbbf24}.tut-trap-card--single .tut-trap-type{color:#f87171}.tut-score-table{background:#ffffff0a;border-radius:10px;overflow:hidden}.tut-score-table-header{background:#60a5fa26;color:#93c5fd;font-weight:600;font-size:.88rem;padding:10px 16px}.tut-score-row{display:flex;align-items:center;gap:12px;padding:10px 16px;font-size:.9rem;border-top:1px solid rgba(255,255,255,.05)}.tut-score-icon{font-size:1.1rem;flex-shrink:0}.tut-score-label{flex:1;color:#ffffffd9}.tut-score-pts{font-weight:700;font-size:1rem;flex-shrink:0}.tut-controls-table{background:#ffffff0a;border-radius:10px;overflow:hidden;font-size:.87rem}.tut-ctrl-row{display:grid;grid-template-columns:1fr 1.4fr;gap:12px;padding:9px 14px;border-top:1px solid rgba(255,255,255,.05);align-items:start}.tut-ctrl-row:first-child{border-top:none}.tut-ctrl-action{font-weight:600;color:#93c5fd}.tut-ctrl-desc{color:#ffffffbf;line-height:1.45}.tut-tips-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}@media(max-width:520px){.tut-tips-grid{grid-template-columns:1fr}}.tut-tip-card{background:#ffffff0d;border:1px solid rgba(255,255,255,.09);border-radius:10px;padding:14px;display:flex;gap:10px;align-items:flex-start;font-size:.87rem}.tut-tip-icon{font-size:1.5rem;flex-shrink:0}.tut-tip-title{font-weight:700;color:#fbbf24;margin-bottom:4px}.tut-tip-desc{color:#ffffffbf;line-height:1.5}.tut-ul{margin:0;padding-left:20px}.tut-ul li{margin-bottom:6px;line-height:1.5}.tut-hint{font-size:.85rem;color:#fff9;margin:0;line-height:1.55}.tut-footer{justify-content:space-between!important;align-items:center}.tut-step-counter{font-size:.85rem;color:#ffffff73}.tut-nav-btns{display:flex;gap:10px}.password-gate{position:fixed;top:0;left:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0f2027,#203a43,#2c5364);z-index:10000}.password-gate-container{background:#fffffff2;border-radius:20px;padding:60px 50px;max-width:450px;width:90%;box-shadow:0 30px 60px #0000004d;text-align:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.password-gate-title{font-size:3em;margin:0 0 10px;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:800;letter-spacing:-1px}.password-gate-subtitle{color:#666;font-size:1.1em;margin:0 0 40px;font-weight:500}.password-form{display:flex;flex-direction:column;gap:20px}.password-input-group{position:relative}.password-input{width:100%;padding:16px 20px;font-size:1.1em;border:2px solid #e0e0e0;border-radius:12px;outline:none;transition:all .3s ease;background:#fff;text-align:center;letter-spacing:2px}.password-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.password-input.error{border-color:#f44336;animation:shake .5s ease}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-10px)}75%{transform:translate(10px)}}.error-message{position:absolute;top:100%;left:0;right:0;color:#f44336;font-size:.9em;margin-top:5px;font-weight:500}.password-submit-btn{padding:16px 40px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;font-size:1.1em;font-weight:600;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:1px}.password-submit-btn:hover{transform:translateY(-2px);box-shadow:0 10px 30px #667eea4d}.password-submit-btn:active{transform:translateY(0)}.password-hint{margin-top:30px;padding-top:30px;border-top:1px solid #e0e0e0;color:#999;font-size:.9em;display:flex;align-items:center;justify-content:center;gap:8px}.password-hint:before{content:"🔒";font-size:1.2em}@media(max-width:480px){.password-gate-container{padding:30px 20px;width:95%}.password-gate-title{font-size:2.2em}.password-gate-subtitle{font-size:1em;margin-bottom:25px}.password-input{padding:13px 15px;font-size:1em}.password-submit-btn{padding:13px 30px;font-size:1em}}.save-load-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;justify-content:center;align-items:center;z-index:10000;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.save-load-modal{background:linear-gradient(145deg,#1a1a2e,#16213e);border-radius:15px;padding:30px;max-width:700px;width:90%;max-height:80vh;overflow-y:auto;box-shadow:0 10px 40px #00000080;border:2px solid rgba(255,255,255,.1)}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:25px;padding-bottom:15px;border-bottom:2px solid rgba(255,255,255,.1)}.modal-header h2{color:#fff;margin:0;font-size:28px}.close-btn{background:none;border:none;color:#fff;font-size:32px;cursor:pointer;transition:transform .2s;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%}.close-btn:hover{background:#ffffff1a;transform:scale(1.1)}.save-section{display:flex;gap:15px;margin-bottom:25px;flex-wrap:wrap}.save-section input{flex:1;padding:12px 15px;border-radius:8px;border:2px solid rgba(255,255,255,.2);background:#ffffff0d;color:#fff;font-size:16px;transition:all .3s}.save-section input:focus{outline:none;border-color:#667eea;background:#ffffff1a}.current-game-info{width:100%;display:flex;gap:20px;color:#ffffffb3;font-size:14px}.saves-list{display:flex;flex-direction:column;gap:15px;max-height:400px;overflow-y:auto;padding-right:10px}.no-saves{text-align:center;color:#ffffff80;padding:40px;font-size:18px}.save-item{background:#ffffff0d;border-radius:10px;padding:15px;border:2px solid transparent;cursor:pointer;transition:all .3s;display:flex;justify-content:space-between;align-items:center}.save-item:hover{background:#ffffff14;border-color:#fff3}.save-item.selected{border-color:#667eea;background:#667eea1a}.save-main{flex:1}.save-item h3{color:#fff;margin:0 0 8px;font-size:18px}.save-date{color:#ffffff80;font-size:12px;margin-bottom:10px}.save-details{display:flex;gap:10px;margin-bottom:10px}.round-badge,.player-badge{padding:4px 10px;border-radius:15px;font-size:12px;font-weight:700}.round-badge{background:#4caf5033;color:#4caf50;border:1px solid #4caf50}.player-badge{background:#2196f333;color:#2196f3;border:1px solid #2196f3}.scores-preview{display:flex;gap:8px;flex-wrap:wrap}.score-badge{padding:3px 8px;border-radius:5px;font-size:11px;background:#ffffff1a;color:#ffffffb3}.score-badge.rank-1{background:linear-gradient(135deg,gold,#ffed4e);color:#1a1a2e}.score-badge.rank-2{background:linear-gradient(135deg,silver,#e8e8e8);color:#1a1a2e}.score-badge.rank-3{background:linear-gradient(135deg,#cd7f32,#e6a05a);color:#1a1a2e}.save-actions{display:flex;gap:8px}.btn{padding:10px 20px;border-radius:8px;border:none;cursor:pointer;font-weight:700;transition:all .2s;font-size:14px}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 15px #667eea66}.btn-secondary{background:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.2)}.btn-secondary:hover{background:#ffffff26}.btn-danger{background:linear-gradient(135deg,#f44336,#e91e63);color:#fff}.btn-danger:hover{box-shadow:0 4px 15px #f4433666}.btn-small{padding:6px 12px;font-size:12px}.btn:disabled{opacity:.5;cursor:not-allowed}.modal-footer{display:flex;justify-content:center;gap:15px;margin-top:25px;padding-top:20px;border-top:1px solid rgba(255,255,255,.1)}.saves-list::-webkit-scrollbar{width:8px}.saves-list::-webkit-scrollbar-track{background:#ffffff0d;border-radius:4px}.saves-list::-webkit-scrollbar-thumb{background:#fff3;border-radius:4px}.saves-list::-webkit-scrollbar-thumb:hover{background:#ffffff4d}@media(max-width:600px){.save-load-modal{padding:20px;width:95%}.modal-header h2{font-size:22px}.save-section{flex-direction:column}.save-item{flex-direction:column;align-items:flex-start}.save-actions{width:100%;margin-top:10px}.save-actions .btn{flex:1}}.local-game-container{width:100%;flex:1;display:flex;flex-direction:column;background:var(--bg-primary, #1a1a2e);min-height:0}.local-game-header{display:flex;justify-content:space-between;align-items:center;padding:20px 30px;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid rgba(255,255,255,.2)}.game-info{display:flex;gap:30px;align-items:center}.game-title{font-size:24px;font-weight:700;color:#fff;margin:0}.current-player-indicator{padding:8px 16px;background:#fff3;border-radius:20px}.player-badge{font-size:16px;font-weight:600;color:#fff}.player-badge.player1{text-shadow:0 0 10px rgba(100,150,255,.8)}.player-badge.player2{text-shadow:0 0 10px rgba(255,100,100,.8)}.game-stats{display:flex;gap:20px;color:#fff;font-size:14px}.game-controls{display:flex;gap:10px}.save-button,.load-button,.back-button{padding:10px 20px;background:#fff3;border:2px solid rgba(255,255,255,.3);border-radius:8px;color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease}.save-button:hover,.load-button:hover,.back-button:hover{background:#ffffff4d;transform:translateY(-2px)}.save-button{background:#4caf5033;border-color:#4caf5080}.save-button:hover{background:#4caf504d}.load-button{background:#2196f333;border-color:#2196f380}.load-button:hover{background:#2196f34d}.local-game-content{flex:1;display:flex;justify-content:center;align-items:stretch;padding:0;min-height:0;overflow:auto}.game-over-modal{position:fixed;top:0;left:0;width:100%;height:100%;background:#000c;display:flex;justify-content:center;align-items:center;z-index:1000}.game-over-modal .modal-content{background:#fff;padding:40px;border-radius:16px;box-shadow:0 20px 60px #00000080;text-align:center;max-width:500px;animation:slideIn .3s ease}.winner-text{font-size:24px;font-weight:700;color:#667eea;margin:20px 0}.final-scores{margin:30px 0;text-align:left}.final-scores h3{margin-bottom:15px;color:#333}.score-line{padding:8px 12px;background:#f5f5f5;border-radius:6px;margin:5px 0;font-size:14px}.menu-button{padding:12px 30px;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease}.menu-button:hover{transform:translateY(-2px);box-shadow:0 10px 30px #667eea66}@media(max-width:768px){.local-game-header{flex-direction:column;gap:12px;padding:12px 15px;align-items:flex-start}.game-info{gap:12px;flex-wrap:wrap}.game-title{font-size:18px}.game-stats{gap:10px;flex-wrap:wrap;font-size:12px}.game-controls{flex-wrap:wrap;gap:8px;width:100%}.save-button,.load-button,.back-button{padding:8px 14px;font-size:13px}}@media(max-width:480px){.local-game-header{padding:10px 12px}.game-title{font-size:16px}.save-button,.load-button,.back-button{padding:7px 12px;font-size:12px}.game-over-modal .modal-content{padding:20px;max-width:95%}.winner-text{font-size:18px}.menu-button{padding:10px 20px;font-size:14px}}.ai-vs-ai-container{width:100%;flex:1;min-height:0;display:flex;flex-direction:column;background:linear-gradient(135deg,#1a1a2e,#16213e);overflow:hidden}.ai-game-header{display:flex;flex-wrap:wrap;align-items:center;gap:6px 12px;padding:8px 16px;flex-shrink:0;background:#ffffff0d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid rgba(255,255,255,.1)}.game-title{font-size:16px;font-weight:700;color:#fff;margin:0;white-space:nowrap}.ai-players-info{display:flex;align-items:center;gap:8px;padding:4px 10px;background:#ffffff1a;border-radius:20px}.ai-player-badge{font-size:12px;font-weight:600;color:#fff;padding:3px 8px;border-radius:12px;white-space:nowrap}.ai-player-badge.player1{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 0 8px #667eea66}.ai-player-badge.player2{background:linear-gradient(135deg,#f093fb,#f5576c);box-shadow:0 0 8px #f5576c66}.vs-text{color:#fff;font-weight:700;font-size:12px}.game-stats{display:flex;gap:6px;color:#fffc;font-size:12px}.game-stats span{padding:3px 6px;background:#ffffff0d;border-radius:4px;white-space:nowrap}.speed-control{display:flex;align-items:center;gap:4px;padding:4px 10px;background:#ffffff1a;border-radius:16px}.speed-control label{color:#fff;font-weight:600;font-size:12px;margin-right:2px;white-space:nowrap}.speed-btn{padding:6px 12px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:5px;color:#fff;font-size:12px;cursor:pointer;transition:all .2s ease}.speed-btn:hover{background:#fff3}.speed-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;box-shadow:0 0 10px #667eea4d}.pause-button,.restart-button,.back-button,.save-button,.load-button,.undo-button{padding:6px 14px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:6px;color:#fff;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap}.pause-button{background:#ffc10733;border-color:#ffc10780}.pause-button:hover{background:#ffc1074d;transform:translateY(-2px)}.restart-button{background:#4caf5033;border-color:#4caf5080}.restart-button:hover{background:#4caf504d;transform:translateY(-2px)}.back-button:hover,.save-button:hover,.load-button:hover{background:#fff3;transform:translateY(-2px)}.undo-button{background:#6495ed33;border-color:#6495ed80}.undo-button:hover:not(:disabled){background:#6495ed4d;transform:translateY(-2px)}.undo-button:disabled{opacity:.3;cursor:not-allowed}.game-controls{display:flex;flex-wrap:wrap;gap:4px;align-items:center}.ai-game-content{flex:1;display:flex;justify-content:center;align-items:stretch;padding:0;min-height:0;overflow:auto}.ai-game-content .game-info-header{display:none}.game-over-modal{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000d9;display:flex;justify-content:center;align-items:center;z-index:1000;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.game-over-modal .modal-content{background:linear-gradient(145deg,#1a1a2e,#16213e);padding:40px;border-radius:16px;box-shadow:0 20px 60px #000000b3;text-align:center;max-width:500px;animation:slideIn .3s ease;border:2px solid rgba(255,255,255,.1)}@keyframes slideIn{0%{opacity:0;transform:translateY(-50px)}to{opacity:1;transform:translateY(0)}}.winner-text{font-size:24px;font-weight:700;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;margin:20px 0}.final-scores{margin:30px 0;text-align:left;background:#ffffff0d;padding:20px;border-radius:10px}.final-scores h3{margin-bottom:15px;color:#fff}.score-line{padding:8px 12px;background:#ffffff1a;border-radius:6px;margin:5px 0;font-size:14px;color:#fffc}.modal-actions{display:flex;gap:15px;justify-content:center;margin-top:20px}.modal-actions button{padding:12px 30px;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease}.modal-actions .restart-button{background:linear-gradient(135deg,#76,175,80,#4caf50);color:#fff}.modal-actions .menu-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.modal-actions button:hover{transform:translateY(-2px);box-shadow:0 10px 30px #0006}@media(max-width:768px){.ai-game-header{padding:4px 8px;gap:3px 6px}.game-title{font-size:13px}.ai-player-badge{font-size:10px;padding:2px 5px}.ai-players-info{padding:2px 6px;gap:4px}.game-stats{font-size:10px}.game-stats span{padding:2px 4px}.speed-btn{padding:3px 7px;font-size:10px}.speed-control{padding:2px 6px;gap:3px}.pause-button,.restart-button,.back-button,.save-button,.load-button,.undo-button{padding:4px 8px;font-size:10px}}@media(max-width:480px){.ai-game-header{padding:4px 8px;gap:3px 6px}.game-title{font-size:12px}.game-stats{display:none}.ai-players-info{flex-wrap:wrap;justify-content:center;gap:3px;padding:2px 5px}.speed-control{flex-wrap:wrap;justify-content:center;gap:2px;padding:2px 5px}.speed-btn{padding:3px 6px;font-size:10px}.pause-button,.restart-button,.back-button,.save-button,.load-button,.undo-button{padding:3px 7px;font-size:10px}.game-over-modal .modal-content{padding:20px;max-width:95%}.modal-actions{flex-direction:column;gap:10px}.modal-actions button{width:100%;padding:10px 20px;font-size:14px}}.tut-ov-wrapper{position:absolute;bottom:0;left:0;right:0;display:flex;justify-content:center;pointer-events:none;z-index:200;padding:0 16px 20px}.tut-ov-wrapper.tut-ov--blocking{top:0;background:#00000073;pointer-events:all;align-items:flex-end}.tut-ov-card{background:#0a0c18f7;border:1px solid rgba(255,255,255,.1);border-radius:14px;padding:20px 24px 18px;max-width:580px;width:100%;pointer-events:all;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 -6px 32px #0009}.tut-ov-chapters{display:flex;gap:8px;margin-bottom:18px}.tut-ov-chapter{flex:1;display:flex;flex-direction:column;align-items:stretch;gap:5px}.tut-ov-chapter-bar{height:4px;border-radius:2px;background:#ffffff1f;transition:background .3s}.tut-ov-chapter.done .tut-ov-chapter-bar{background:#4ade80}.tut-ov-chapter.active .tut-ov-chapter-bar{background:#60a5fa}.tut-ov-chapter-label{font-size:10px;text-align:center;color:#ffffff59;letter-spacing:.03em;text-transform:uppercase;transition:color .3s}.tut-ov-chapter.active .tut-ov-chapter-label{color:#60a5fa}.tut-ov-chapter.done .tut-ov-chapter-label{color:#4ade80}.tut-ov-title{margin:0 0 10px;font-size:17px;font-weight:700;color:#fff;line-height:1.3}.tut-ov-message{margin:0;font-size:14px;color:#ffffffc7;line-height:1.65;white-space:pre-line}.tut-ov-footer{margin-top:16px;display:flex;justify-content:flex-end;align-items:center}.tut-ov-btn{background:#3b82f6;color:#fff;border:none;border-radius:8px;padding:10px 26px;font-size:15px;font-weight:600;cursor:pointer;transition:background .18s,transform .12s}.tut-ov-btn:hover{background:#2563eb;transform:translateY(-1px)}.tut-ov-btn:active{transform:translateY(0)}.tut-ov-move-hint{font-size:13px;color:#fff6;font-style:italic}.tutorial-game-container{position:relative}.hint-popup-container{position:fixed;bottom:24px;right:24px;display:flex;flex-direction:column;gap:10px;z-index:200;pointer-events:none;max-width:320px}.hint-card{display:flex;align-items:flex-start;gap:10px;background:#0f1423eb;border:1px solid rgba(255,255,255,.12);border-radius:10px;padding:12px 14px 0;overflow:hidden;pointer-events:all;cursor:pointer;box-shadow:0 4px 20px #00000080;position:relative}.hint-card--capture{border-left:3px solid #e74c3c}.hint-card--trap{border-left:3px solid #f39c12}.hint-card--burn{border-left:3px solid #e67e22}.hint-card--divide{border-left:3px solid #9b59b6}.hint-card--enter{animation:hint-slide-in .35s cubic-bezier(.175,.885,.32,1.275) forwards}.hint-card--exit{animation:hint-slide-out .35s ease-in forwards}@keyframes hint-slide-in{0%{transform:translate(110%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes hint-slide-out{0%{transform:translate(0);opacity:1}to{transform:translate(110%);opacity:0}}.hint-card__icon{font-size:20px;line-height:1;margin-top:2px;flex-shrink:0}.hint-card__body{flex:1;padding-bottom:12px}.hint-card__title{font-size:13px;font-weight:700;color:#fff;margin-bottom:4px;letter-spacing:.02em}.hint-card__message{font-size:12px;color:#ffffffb8;line-height:1.45}.hint-card__progress{position:absolute;bottom:0;left:0;right:0;height:3px;background:#ffffff14}.hint-card__progress-bar{height:100%;background:#ffffff59;animation:hint-progress linear forwards;transform-origin:left}@keyframes hint-progress{0%{width:100%}to{width:0%}}@media(max-width:600px){.hint-popup-container{bottom:12px;right:8px;left:8px;max-width:unset}}.trap-test-page{min-height:100vh;background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460);color:#e0e0e0;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.trap-test-header{display:flex;align-items:center;gap:20px;padding:15px 30px;background:#0000004d;border-bottom:1px solid rgba(255,255,255,.1)}.trap-test-header h1{margin:0;font-size:1.8rem;background:linear-gradient(90deg,#00d4ff,#0f8);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.back-button{padding:10px 20px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:8px;color:#fff;cursor:pointer;transition:all .2s}.back-button:hover{background:#fff3}.session-id{margin-left:auto;font-size:.85rem;color:#888;font-family:monospace}.trap-test-content{display:grid;grid-template-columns:350px 1fr 350px;gap:20px;padding:20px;height:calc(100vh - 80px)}.panel{background:#ffffff0d;border-radius:12px;padding:20px;border:1px solid rgba(255,255,255,.1);overflow-y:auto}.panel h2{margin:0 0 15px;font-size:1.2rem;color:#00d4ff;border-bottom:1px solid rgba(0,212,255,.3);padding-bottom:10px}.scenario-group{margin-bottom:20px}.scenario-group h3{font-size:.9rem;text-transform:uppercase;letter-spacing:1px;margin:0 0 10px;padding:5px 10px;border-radius:4px}.trap-type-escapable{background:#3498db4d;color:#3498db}.trap-type-force-based,.trap-type-force_based{background:#e74c3c4d;color:#e74c3c}.trap-type-single-color,.trap-type-single_color{background:#2ecc714d;color:#2ecc71}.trap-type-other{background:#95a5a64d;color:#95a5a6}.scenario-list{display:flex;flex-direction:column;gap:5px}.scenario-item{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;background:#ffffff08;border-radius:6px;cursor:pointer;border:1px solid transparent;transition:all .2s}.scenario-item:hover{background:#ffffff14}.scenario-item.selected{border-color:#00d4ff;background:#00d4ff1a}.scenario-item.loaded{border-color:#2ecc71}.scenario-name{font-size:.9rem}.scenario-side{font-size:1.1rem}.scenario-details{margin-top:20px;padding:15px;background:#0003;border-radius:8px}.scenario-details h3{margin:0 0 10px;color:#00d4ff}.scenario-details p{margin:5px 0;font-size:.9rem;color:#bbb}.load-btn{margin-top:15px;width:100%;padding:12px;background:linear-gradient(90deg,#00d4ff,#0f8);border:none;border-radius:8px;color:#000;font-weight:700;cursor:pointer;transition:all .2s}.load-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 20px #00d4ff4d}.load-btn:disabled{opacity:.5;cursor:not-allowed}.loaded-info{padding:15px;background:#00d4ff1a;border-radius:8px;margin-bottom:20px}.loaded-info h3{margin:0 0 10px;color:#fff}.preset-choice{margin-bottom:20px;padding:15px;background:#3498db1a;border-radius:8px;border:1px solid rgba(52,152,219,.3)}.preset-choice h4{margin:0 0 10px;color:#3498db}.preset-choice p{margin:0 0 10px;font-size:.9rem;color:#bbb}.side-buttons{display:flex;flex-wrap:wrap;gap:8px}.side-btn{width:50px;height:50px;border:2px solid;border-radius:8px;cursor:pointer;font-size:1.2rem;transition:all .2s;display:flex;flex-direction:column;align-items:center;justify-content:center}.side-btn:hover{transform:scale(1.1)}.action-buttons{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}.execute-btn{padding:15px;background:linear-gradient(90deg,#2ecc71,#27ae60);border:none;border-radius:8px;color:#fff;font-size:1.1rem;font-weight:700;cursor:pointer;transition:all .2s}.execute-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 20px #2ecc714d}.execute-btn:disabled{opacity:.5;cursor:not-allowed}.end-round-btn{padding:12px;background:linear-gradient(90deg,#f39c12,#e67e22);border:none;border-radius:8px;color:#fff;font-weight:700;cursor:pointer;transition:all .2s}.end-round-btn:hover:not(:disabled){transform:translateY(-2px)}.reset-btn{padding:12px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:8px;color:#fff;cursor:pointer;transition:all .2s}.reset-btn:hover:not(:disabled){background:#fff3}.result-box{padding:20px;border-radius:8px;margin-bottom:20px}.result-box.trap-triggered{background:#e74c3c1a;border:1px solid rgba(231,76,60,.3)}.result-box.no-trap{background:#2ecc711a;border:1px solid rgba(46,204,113,.3)}.result-box h3{margin:0 0 15px;color:#fff}.result-box p{margin:8px 0}.trap-alert{font-size:1.2rem;font-weight:700;color:#e74c3c;animation:pulse 1s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.burned{color:#e74c3c;font-weight:700}.pending{color:#f39c12;font-weight:700}.pending-traps{padding:15px;background:#f39c121a;border-radius:8px;border:1px solid rgba(243,156,18,.3)}.pending-traps h3{margin:0 0 10px;color:#f39c12}.pending-trap-item{padding:10px;background:#0003;border-radius:4px;margin-top:8px}.pending-trap-item p{margin:3px 0;font-size:.85rem}.no-scenario{text-align:center;color:#666;padding:40px}.error-message{padding:15px;background:#e74c3c33;border:1px solid #e74c3c;border-radius:8px;color:#e74c3c;margin-top:15px}.log-content{height:calc(100% - 100px);overflow-y:auto;font-family:Consolas,Monaco,monospace;font-size:.85rem;background:#0000004d;border-radius:8px;padding:10px}.log-entry{padding:5px 0;border-bottom:1px solid rgba(255,255,255,.05);color:#aaa}.log-entry:last-child{border-bottom:none}.no-logs{color:#666;text-align:center;padding:20px}.clear-log-btn{margin-top:10px;width:100%;padding:10px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:#888;cursor:pointer;transition:all .2s}.clear-log-btn:hover{background:#ffffff1a;color:#fff}.loading-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.spinner{width:50px;height:50px;border:3px solid rgba(255,255,255,.1);border-top-color:#00d4ff;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:1200px){.trap-test-content{grid-template-columns:1fr;grid-template-rows:auto auto auto}.panel{max-height:400px}}@media(max-width:768px){.trap-test-header{padding:12px 15px;gap:12px}.trap-test-header h1{font-size:1.3rem}.session-id{display:none}}@media(max-width:480px){.trap-test-header{padding:10px 12px}.trap-test-header h1{font-size:1.1rem}.back-button{padding:8px 14px;font-size:13px}}.trap-notification-container{position:fixed;top:20px;right:20px;z-index:1000;animation:slideInRight .4s cubic-bezier(.68,-.55,.265,1.55)}.trap-notification-container.closing{animation:slideOutRight .3s ease}@keyframes slideInRight{0%{transform:translate(400px);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slideOutRight{0%{transform:translate(0);opacity:1}to{transform:translate(400px);opacity:0}}.trap-notification{background:linear-gradient(135deg,#111827fa,#1f2937fa);border:2px solid rgba(255,87,34,.6);border-radius:15px;padding:20px;min-width:350px;max-width:450px;box-shadow:0 10px 40px #00000080,0 0 20px #ff57224d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.trap-notification-header{display:flex;align-items:flex-start;gap:12px;margin-bottom:16px}.trap-icon{font-size:32px;animation:pulse 2s infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.trap-title{flex:1}.trap-title h3{margin:0;font-size:20px;color:#ff5722;font-weight:700;text-transform:uppercase;letter-spacing:1px}.trap-position{display:block;font-size:14px;color:#ffffffb3;margin-top:4px}.trap-close-btn{background:#ffffff1a;border:none;border-radius:50%;width:28px;height:28px;font-size:24px;line-height:1;color:#fff9;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.trap-close-btn:hover{background:#fff3;color:#fff;transform:rotate(90deg)}.trap-type-badge{display:inline-block;padding:6px 12px;background:linear-gradient(135deg,#9333ea4d,#ec48994d);border:1px solid rgba(147,51,234,.5);border-radius:8px;color:#ec4899;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;margin-bottom:16px}.trap-surrounding{margin-bottom:16px}.trap-label{display:block;font-size:13px;color:#fff9;margin-bottom:8px;font-weight:500}.trap-sides{display:flex;flex-wrap:wrap;gap:8px}.side-badge{padding:6px 12px;border-radius:8px;font-size:13px;font-weight:700;border:1px solid rgba(0,0,0,.3);box-shadow:0 2px 8px #0003;transition:all .2s ease}.side-badge:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.trap-result{padding:12px;background:#ffffff0d;border-left:3px solid #4CAF50;border-radius:6px;color:#fff;font-size:15px;font-weight:500;margin-bottom:12px}.trap-result:has(:is(🔥)){border-left-color:#ff5722}.trap-choice-reason{font-size:12px;color:#ffffff80;font-style:italic;margin-bottom:12px;padding-left:12px}.trap-progress-bar{height:3px;background:#ffffff1a;border-radius:2px;overflow:hidden;margin-top:16px}.trap-progress-fill{height:100%;background:linear-gradient(90deg,#9333ea,#ec4899);animation:progressShrink 5s linear;box-shadow:0 0 10px #9333ea80}@keyframes progressShrink{0%{width:100%}to{width:0%}}@media(max-width:768px){.trap-notification-container{top:10px;right:10px;left:10px}.trap-notification{min-width:auto;max-width:none;padding:16px}.trap-icon{font-size:28px}.trap-title h3{font-size:18px}}@media(prefers-color-scheme:light){.trap-notification{background:linear-gradient(135deg,#fffffffa,#f5f5f5fa);border-color:#ff572266}.trap-title h3{color:#d84315}.trap-position{color:#0009}.trap-close-btn{background:#0000000d;color:#0009}.trap-close-btn:hover{background:#0000001a;color:#000}.trap-result{background:#00000008;color:#000}.trap-choice-reason{color:#00000080}.trap-progress-bar{background:#0000001a}}.app{width:100%;min-height:100vh;display:flex;flex-direction:column}.app-header{display:flex;justify-content:space-between;align-items:center;padding:12px 20px;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);flex-shrink:0}.app-header h1{color:#fff;font-size:1.8em;margin:0}.connection-status{color:#fff;font-weight:700;display:flex;align-items:center;gap:5px;font-size:14px}.app-main{flex:1;display:flex;flex-direction:column;min-height:0;overflow:hidden}.app-main:has(.main-menu),.app-main:has(.lobby-container){max-width:1400px;margin:20px auto;background:#fffffff2;border-radius:15px;padding:30px}.app-main:has(.game-board-container),.app-main:has(.local-game-container),.app-main:has(.ai-vs-ai-container){background:transparent;padding:0;max-width:none;margin:0}@media(max-width:768px){.app-header{padding:10px 12px}.app-header h1{font-size:1.4em}.app-main:has(.main-menu),.app-main:has(.lobby-container){margin:10px;padding:15px}}@media(max-width:480px){.app-header{padding:8px 10px}.app-header h1{font-size:1.2em}.connection-status{font-size:12px}.app-main:has(.main-menu),.app-main:has(.lobby-container){margin:5px;padding:10px}}.game-finished{text-align:center;padding:50px}.game-finished h2{color:#333;margin-bottom:30px;font-size:2em}.game-finished button{padding:15px 30px;font-size:1.2em;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:10px;cursor:pointer;transition:transform .2s}.game-finished button:hover{transform:scale(1.05)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#1a1a2e;min-height:100vh;overflow-x:hidden;-webkit-text-size-adjust:100%}#root{min-height:100vh;width:100%}
