body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.modal-overlay{align-items:center;background-color:#000000b3;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal-content{background-color:#fff;border-radius:8px;box-shadow:0 4px 8px #0003;color:#333;max-width:500px;padding:20px;width:90%}.load-modal{max-width:600px}.custom-load-modal{max-width:700px}.modal-content h2{border-bottom:1px solid #ddd;color:#333;font-size:1.5rem;margin-bottom:16px;margin-top:0;padding-bottom:10px}.modal-body{margin-bottom:20px;max-height:400px;overflow-y:auto}.form-group{margin-bottom:15px}.form-group label{display:block;font-weight:700;margin-bottom:5px}.form-control{border:1px solid #ccc;border-radius:4px;font-size:16px;padding:8px 12px;width:100%}.modal-footer{border-top:1px solid #ddd;justify-content:space-between;padding-top:15px}.load-options,.modal-footer{display:flex;gap:10px}.btn-primary,.btn-secondary{font-size:14px;padding:8px 16px}.btn-primary{background-color:#007bff}.btn-primary:hover{background-color:#0069d9}.btn-primary:disabled{background-color:#ccc}.btn-secondary{background-color:#6c757d;color:#fff}.btn-secondary:hover{background-color:#5a6268}.btn-secondary:disabled{background-color:#adb5bd;cursor:not-allowed}.error-message{background-color:#dc35451a;color:#dc3545;margin-bottom:15px;padding:8px}.status-message{border-radius:4px;margin-bottom:15px;padding:8px}.status-message.success{background-color:#28a7451a;color:#28a745}.status-message.error{background-color:#dc35451a;color:#dc3545}.loading,.no-saves{color:#666;padding:20px;text-align:center}.no-saves{font-style:italic}.saves-list{display:flex;flex-direction:column;gap:10px}.save-item{align-items:center;border:1px solid #ddd;border-radius:4px;cursor:pointer;display:flex;justify-content:space-between;padding:12px;transition:background-color .2s}.save-item:hover{background-color:#f5f5f5}.save-item.selected{background-color:#e6f7ff;border-color:#1890ff}.save-details{flex:1 1}.save-name{font-weight:700;margin-bottom:4px}.save-timestamp{color:#666;font-size:12px;margin-bottom:4px}.save-info{color:#666;display:flex;font-size:12px;gap:10px}.save-info span{background-color:#f0f0f0;border-radius:4px;padding:2px 6px}.delete-save{align-items:center;background-color:#dc3545;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:18px;height:24px;justify-content:center;line-height:1;width:24px}.delete-save:hover{background-color:#c82333}.save-game-info{background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:4px;margin-bottom:15px;padding:12px}.save-game-info h3{color:#444;font-size:16px;margin-bottom:10px;margin-top:0}.save-game-info h4{color:#555;font-size:14px;margin-bottom:5px;margin-top:10px}.save-game-info p{font-size:14px;margin:5px 0}.player-info ul{list-style-type:none;margin:5px 0;padding-left:0}.player-info li{background-color:#e9ecef;border-radius:3px;font-size:13px;margin-bottom:4px;padding:4px 8px}.player-info li:last-child{margin-bottom:0}.custom-load-info{background-color:#f8f9fa;border-left:4px solid #007bff;border-radius:4px;margin-bottom:15px;padding:10px}.player-settings{grid-gap:15px;gap:15px;margin-bottom:15px}.player-setting{border-radius:6px;box-shadow:0 1px 3px #0000001a;gap:8px;padding:12px}.player-label{font-size:1rem}.player-name-input,.player-setting select{border:1px solid #ddd;border-radius:4px;font-size:.9rem;padding:8px}.home-page{align-items:center;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);display:flex;flex-direction:column;justify-content:center;min-height:100vh;padding:20px}.home-content{background-color:#ffffffe6;border-radius:15px;box-shadow:0 10px 30px #0000001a;max-width:800px;padding:40px;text-align:center}.game-title{color:#333;font-size:3.5rem;margin-bottom:20px;text-shadow:2px 2px 4px #0000001a}.game-description{color:#555;font-size:1.2rem;line-height:1.6;margin-bottom:40px}.home-buttons{display:flex;gap:20px;justify-content:center;margin-top:20px}.vertical-buttons{align-items:center;flex-direction:column;margin-left:auto;margin-right:auto;max-width:300px;width:100%}.vertical-buttons .home-button{margin-bottom:15px;text-align:center;width:100%}.home-button{border:none;border-radius:8px;cursor:pointer;display:inline-block;font-size:1.2rem;font-weight:700;padding:15px 30px;text-decoration:none;transition:all .3s ease}.primary-button{box-shadow:0 4px 6px #4caf504d}.primary-button:hover{background-color:#45a049;box-shadow:0 6px 8px #4caf5066;transform:translateY(-2px)}.load-button{background-color:#ff9800;box-shadow:0 4px 6px #ff98004d;color:#fff}.load-button:hover{background-color:#f57c00;box-shadow:0 6px 8px #ff980066;transform:translateY(-2px)}.editor-button{background-color:#9c27b0;box-shadow:0 4px 6px #9c27b04d;color:#fff}.editor-button:hover{background-color:#7b1fa2;box-shadow:0 6px 8px #9c27b066;transform:translateY(-2px)}.secondary-button{box-shadow:0 4px 6px #2196f34d}.secondary-button:hover{background-color:#0b7dda;box-shadow:0 6px 8px #2196f366;transform:translateY(-2px)}.scenario-button{background-color:#7e57c2;color:#fff}.scenario-button:hover{background-color:#673ab7}.new-game-page{align-items:center;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);display:flex;flex-direction:column;justify-content:center;min-height:100vh;padding:20px}.new-game-container{background-color:#ffffffe6;border-radius:15px;box-shadow:0 10px 30px #0000001a;max-width:800px;padding:30px;width:100%}.new-game-container h1{color:#333;font-size:2.5rem;margin-bottom:30px;text-align:center;text-shadow:1px 1px 2px #0000001a}.setup-section{border-bottom:1px solid #eee;margin-bottom:30px;padding-bottom:20px}.setup-section h2{color:#444;font-size:1.5rem;margin-bottom:15px}.player-count-selector{display:flex;gap:15px;justify-content:center;margin-bottom:20px}.player-count-selector button{background-color:#f8f8f8;border:2px solid #ddd;border-radius:8px;cursor:pointer;font-size:1rem;padding:10px 20px;transition:all .2s}.player-count-selector button:hover{background-color:#eee;border-color:#ccc}.player-count-selector button.active{background-color:#4caf50;border-color:#4caf50;box-shadow:0 2px 4px #4caf504d;color:#fff}.player-settings{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.player-setting{background-color:#f8f8f8;border-radius:8px;box-shadow:0 2px 4px #0000000d;display:flex;flex-direction:column;gap:10px;padding:15px}.player-label{font-size:1.1rem;font-weight:700;text-shadow:0 1px 1px #0000001a}.player-setting select{background-color:#fff;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:.9rem;padding:10px;transition:border-color .2s}.player-setting select:hover{border-color:#aaa}.player-setting select:focus{border-color:#666;box-shadow:0 0 0 2px #0000001a;outline:none}.player-name-input{background-color:#fff;border:1px solid #ddd;border-radius:4px;font-size:.9rem;padding:10px;transition:border-color .2s,box-shadow .2s}.player-name-input:hover{border-color:#aaa}.player-name-input:focus{border-color:#666;box-shadow:0 0 0 2px #0000001a;outline:none}.ai-delay-setting{align-items:center;background-color:#f8f8f8;border-radius:8px;box-shadow:0 2px 4px #0000000d;display:flex;gap:15px;padding:15px}.ai-delay-setting label{color:#555;font-weight:700;min-width:150px}.ai-delay-setting input[type=range]{cursor:pointer;flex:1 1}.ai-delay-setting span{color:#666;font-size:.9rem;min-width:60px;text-align:right}.setup-actions{display:flex;justify-content:space-between;margin-top:30px}.back-button,.start-button{border:none;border-radius:8px;cursor:pointer;font-size:1.1rem;font-weight:700;padding:12px 25px;transition:all .3s ease}.start-button{background-color:#4caf50;box-shadow:0 4px 6px #4caf504d;color:#fff}.start-button:hover{background-color:#45a049;box-shadow:0 6px 8px #4caf5066;transform:translateY(-2px)}.game-board{background-color:#f0f0f0;border:2px solid #333;border-radius:4px;box-shadow:0 4px 8px #0000001a;display:inline-block;padding:4px}.board-cell{background-color:#fff;border:1px solid #999;position:relative;transition:all .2s}.board-row:nth-child(2n) .board-cell:nth-child(odd),.board-row:nth-child(odd) .board-cell:nth-child(2n){background-color:#e0e0e0}.board-cell:hover{background-color:#f8f8f8}.board-cell.selected{background-color:#ffeb3b!important;box-shadow:inset 0 0 0 2px gold}.board-cell.valid-move-move{background-color:#81c784!important}.board-cell.valid-move-attack{background-color:#ef5350!important}.board-cell.valid-move-create{background-color:#64b5f6!important}.board-cell.valid-move-combine,.board-cell.valid-move-upgrade{background-color:#81c784!important}.board-cell.valid-move-move:hover{background-color:#66bb6a!important}.board-cell.valid-move-attack:hover{background-color:#e53935!important}.board-cell.valid-move-create:hover{background-color:#42a5f5!important}.board-cell.valid-move-combine:hover,.board-cell.valid-move-upgrade:hover{background-color:#66bb6a!important}.board-cell.valid-move:before{background-color:#0003;border-radius:50%;content:"";height:12px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);width:12px}.dice{border-radius:8px;box-shadow:0 2px 4px #0003;height:40px;text-shadow:1px 1px 1px #0000004d;transition:transform .2s;width:40px;z-index:1}.dice:hover{transform:scale(1.1)}.game-info{margin-bottom:20px;max-width:600px;position:relative;text-align:center;width:100%}.game-status{margin-bottom:15px}.current-player{font-size:1.5rem;font-weight:700;margin-bottom:10px}.current-player span{font-weight:700;text-shadow:1px 1px 1px #0000001a}.actions{color:#666;font-size:1.2rem}.game-controls{gap:15px;margin-bottom:15px}.control-button{border:none;border-radius:5px;box-shadow:0 2px 4px #0000001a;color:#fff;cursor:pointer;font-size:1rem;font-weight:700;padding:10px 20px;transition:transform .2s,background-color .2s}.end-turn-button{background-color:#ff9800}.end-turn-button:hover{background-color:#f57c00;transform:scale(1.05)}.end-turn-button:disabled{background-color:#ccc;cursor:not-allowed;transform:none}.turn-message{animation:fadeInOut 1.5s ease-in-out;border-radius:10px;box-shadow:0 4px 8px #0003;color:#fff;font-size:2rem;font-weight:700;left:50%;opacity:0;padding:20px 40px;position:fixed;text-shadow:2px 2px 4px #0000004d;top:50%;transform:translate(-50%,-50%);z-index:100}.win-screen{align-items:center;animation:fadeIn .5s ease-in-out;background-color:#000c;bottom:0;display:flex;flex-direction:column;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:200}.win-message{animation:popIn .5s cubic-bezier(.175,.885,.32,1.275) .5s both;border-radius:15px;box-shadow:0 4px 8px #0003;color:#fff;font-size:3rem;font-weight:700;margin-bottom:20px;padding:30px 60px;text-shadow:2px 2px 4px #0000004d}.win-actions{animation:popIn .5s cubic-bezier(.175,.885,.32,1.275) .7s both;display:flex;gap:15px;justify-content:center}.quick-restart-button{background-color:#ff9800;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1.5rem;font-weight:700;padding:15px 30px;transition:transform .2s,background-color .2s}.quick-restart-button:hover{background-color:#f57c00;transform:scale(1.05)}.new-game-button{background-color:#4caf50;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1.5rem;font-weight:700;padding:15px 30px;transition:transform .2s,background-color .2s}.new-game-button:hover{background-color:#45a049;transform:scale(1.05)}@keyframes fadeInOut{0%{opacity:0;transform:translate(-50%,-50%) scale(.95)}25%{opacity:1;transform:translate(-50%,-50%) scale(1)}75%{opacity:1;transform:translate(-50%,-50%) scale(1)}to{opacity:0;transform:translate(-50%,-50%) scale(.95)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes popIn{0%{opacity:0;transform:scale(.3)}to{opacity:1;transform:scale(1)}}.game-controls{display:flex;gap:10px;justify-content:center;margin-top:10px}.game-control-btn{align-items:center;border:none;border-radius:4px;color:#fff;cursor:pointer;display:flex;font-size:14px;gap:6px;padding:8px 16px;transition:all .2s ease}.game-control-btn:hover:not(:disabled){box-shadow:0 2px 4px #0003;transform:translateY(-2px)}.game-control-btn:disabled{cursor:not-allowed;opacity:.6}.save-btn{background-color:#28a745}.save-btn:hover:not(:disabled){background-color:#218838}.load-btn{background-color:#17a2b8}.load-btn:hover:not(:disabled){background-color:#138496}.game-page{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);min-height:100vh;padding:20px}.game-container,.game-page{align-items:center;display:flex;flex-direction:column}.game-container{background-color:#ffffffe6;border-radius:15px;box-shadow:0 10px 30px #0000001a;max-width:800px;padding:30px;position:relative;width:100%}.game-container h1{color:#333;font-size:2.2rem;margin-bottom:20px;text-align:center;text-shadow:1px 1px 2px #0000001a}.ai-thinking{animation:pulse 1.5s infinite;background-color:#000000b3;border-radius:20px;color:#fff;font-size:.9rem;font-weight:700;padding:8px 15px;position:absolute;right:10px;top:10px;z-index:100}.game-actions{display:flex;justify-content:center;margin-top:30px}.menu-button{background-color:#f1f1f1;border:none;border-radius:8px;color:#333;cursor:pointer;font-size:1.1rem;font-weight:700;padding:12px 25px;transition:all .3s ease}.menu-button:hover{background-color:#e0e0e0;box-shadow:0 4px 6px #0000001a;transform:translateY(-2px)}@keyframes pulse{0%{opacity:.7}50%{opacity:1}to{opacity:.7}}.how-to-play-page{align-items:center;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);display:flex;flex-direction:column;min-height:100vh;padding:20px}.how-to-play-container{background-color:#ffffffe6;border-radius:15px;box-shadow:0 10px 30px #0000001a;margin-bottom:30px;max-width:800px;padding:30px;width:100%}.how-to-play-container h1{color:#333;font-size:2.5rem;margin-bottom:30px;text-align:center;text-shadow:1px 1px 2px #0000001a}.rules-section{border-bottom:1px solid #eee;margin-bottom:25px;padding-bottom:20px}.rules-section:last-of-type{border-bottom:none}.rules-section h2{color:#444;font-size:1.5rem;margin-bottom:15px}.rules-section p{color:#555;line-height:1.6;margin-bottom:15px}.rules-section ul{padding-left:20px}.rules-section li{color:#555;line-height:1.6;margin-bottom:10px}.back-button{background-color:#f1f1f1;border:none;border-radius:8px;color:#333;cursor:pointer;display:block;font-size:1.1rem;font-weight:700;margin:30px auto 0;padding:12px 25px;transition:all .3s ease}.back-button:hover{background-color:#e0e0e0;box-shadow:0 4px 6px #0000001a;transform:translateY(-2px)}.map-editor-page{margin:0 auto;max-width:1200px;padding:20px}.editor-container{display:flex;gap:30px;margin-top:20px}.editor-controls{background-color:#f5f5f5;border-radius:8px;box-shadow:0 2px 4px #0000001a;flex:0 0 300px;padding:15px}.editor-board-container{flex:1 1}.control-section{margin-bottom:20px}.map-name-input{border:1px solid #ccc;border-radius:4px;margin-top:8px;padding:8px;width:100%}.game-settings{margin-top:10px}.setting-group{margin-bottom:12px}.setting-group label{color:#555;display:block;font-weight:700;margin-bottom:5px}.setting-input,.setting-select{background-color:#fff;border:1px solid #ccc;border-radius:4px;padding:8px;width:100%}.setting-input{width:80px}.player-buttons{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.player-button{border:none;border-radius:4px;color:#fff;cursor:pointer;padding:8px 15px;text-shadow:0 1px 1px #0006}.player-button.selected{box-shadow:0 0 0 3px #000}.player-red{background-color:#e74c3c}.player-blue{background-color:#3498db}.player-green{background-color:#2ecc71}.player-yellow{background-color:#f1c40f}.dice-options{display:flex;flex-direction:column;gap:8px;margin-top:10px}.dice-option{background-color:#fff;border:1px solid #ddd;border-radius:4px;cursor:pointer;padding:8px;text-align:left}.dice-option.selected{background-color:#e0e0e0;border-color:#aaa;font-weight:700}.editor-actions{display:flex;flex-direction:column;gap:10px;margin-top:20px}.editor-button{border:none;border-radius:4px;cursor:pointer;font-weight:700;padding:10px}.primary-button{background-color:#4caf50;color:#fff}.secondary-button{background-color:#2196f3;color:#fff}.cancel-button{background-color:#f44336;color:#fff}.save-status{border-radius:4px;margin-top:15px;padding:8px;text-align:center}.save-status.success{background-color:#dff0d8;color:#3c763d}.save-status.error{background-color:#f2dede;color:#a94442}.editor-board{border:2px solid #333;display:flex;flex-direction:column}.board-cell,.board-row{display:flex}.board-cell{align-items:center;background-color:#f9f9f9;border:1px solid #ccc;cursor:pointer;height:60px;justify-content:center;width:60px}.board-cell:hover{background-color:#eaeaea}.dice{align-items:center;border-radius:4px;color:#fff;display:flex;font-size:20px;font-weight:700;height:45px;justify-content:center;text-shadow:0 1px 1px #0006;width:45px}.editor-instructions{color:#555;font-style:italic;margin-bottom:15px}.maps-list{margin-top:10px;max-height:300px;overflow-y:auto}.map-item{border:1px solid #ddd;border-radius:4px;cursor:pointer;margin-bottom:8px;padding:10px;transition:background-color .2s}.map-item:hover{background-color:#f5f5f5}.map-item.selected{background-color:#e3f2fd;border-color:#2196f3}.map-details{display:flex;flex-direction:column}.map-name{font-weight:700;margin-bottom:4px}.map-timestamp{color:#777;font-size:.8rem}.map-description-input{border:1px solid #ccc;border-radius:4px;font-family:inherit;margin-bottom:10px;min-height:80px;padding:8px;resize:vertical;width:100%}.map-description-input:disabled{background-color:#f5f5f5;color:#999;cursor:not-allowed}.scenario-option{align-items:center;display:flex;margin-top:5px}.scenario-option label{align-items:center;color:#444;cursor:pointer;display:flex;font-size:.9rem}.scenario-option input[type=checkbox]{margin-right:8px}.scenarios-page{margin:0 auto;max-width:800px;padding:20px}.page-title{color:#333;margin-bottom:10px;text-align:center}.scenarios-description{color:#666;margin-bottom:30px;text-align:center}.scenarios-list{display:flex;flex-direction:column;gap:15px;margin-bottom:30px}.scenario-item{background-color:#f5f5f5;border:2px solid #ddd;border-radius:8px;cursor:pointer;padding:15px;transition:all .3s ease}.scenario-item:hover{background-color:#eef5ff;border-color:#b8d8ff}.scenario-item.selected{background-color:#e2f0ff;border-color:#4a90e2;box-shadow:0 2px 8px #4a90e233}.scenario-name{color:#333;margin:0 0 8px}.scenario-description{color:#666;font-size:.9rem;margin:0}.scenarios-actions{display:flex;gap:15px;justify-content:center;margin-top:20px}.btn-primary,.btn-secondary{border:none;border-radius:4px;cursor:pointer;font-weight:600;padding:10px 20px;transition:all .2s ease}.btn-primary{background-color:#4a90e2;color:#fff}.btn-primary:hover:not(:disabled){background-color:#3a7bc8}.btn-primary:disabled{background-color:#a5c6f0;cursor:not-allowed}.btn-secondary{background-color:#f5f5f5;border:1px solid #ddd;color:#333}.btn-secondary:hover{background-color:#e5e5e5}.loading-spinner{color:#666;padding:30px;text-align:center}.error-message{background-color:#ffebee;border-radius:4px;color:#d32f2f;margin:20px 0;padding:15px;text-align:center}.notification{align-items:center;animation:slideIn .3s ease-out;border-radius:6px;box-shadow:0 4px 12px #00000026;display:flex;justify-content:space-between;max-width:400px;min-width:250px;padding:12px 16px;position:fixed;right:20px;top:20px;z-index:1100}@keyframes slideIn{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}.notification.success{background-color:#e6f7e9;border-left:4px solid #28a745;color:#1e7e34}.notification.error{background-color:#fce8e8;border-left:4px solid #dc3545;color:#c82333}.notification-content{align-items:center;display:flex;gap:10px}.notification-icon{font-size:1.2rem;font-weight:700}.notification-message{font-size:14px}.notification-close{align-items:center;background:none;border:none;border-radius:50%;cursor:pointer;display:flex;font-size:18px;height:24px;justify-content:center;line-height:1;opacity:.7;padding:0;width:24px}.notification-close:hover{opacity:1}.success .notification-close{color:#1e7e34}.error .notification-close{color:#c82333}.App{background-color:#282c34;min-height:100vh;text-align:center}.App-header{align-items:center;color:#fff;display:flex;flex-direction:column;justify-content:flex-start;min-height:100vh;padding-top:2rem}h1{color:#61dafb;margin-bottom:2rem}
/*# sourceMappingURL=main.4624934b.css.map*/