*{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}#root{width:100vw;min-height:100vh}.landing-page{min-height:100vh;background:#fff;padding:40px 20px;display:flex;flex-direction:column;align-items:center}.header{text-align:center;margin-bottom:60px;animation:fadeInDown .8s ease}.title{font-size:3.5rem;font-weight:800;color:#333;margin:0 0 20px;text-shadow:none}.subtitle{font-size:1.5rem;color:#666;margin:0;font-weight:300}.games-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:30px;max-width:1200px;width:100%;margin-bottom:60px}.game-card{background:#fff;border-radius:16px;padding:40px 30px;text-align:center;text-decoration:none;color:#333;transition:transform .3s ease,box-shadow .3s ease;box-shadow:0 4px 20px #0000001a;animation:fadeInUp .8s ease}.game-card:hover{transform:translateY(-10px);box-shadow:0 12px 40px #0003}.game-icon{font-size:4rem;margin-bottom:20px;animation:bounce 2s ease infinite}.game-card:hover .game-icon{animation-play-state:paused}.game-title{font-size:2rem;font-weight:700;margin:0 0 15px;color:#000}.game-description{font-size:1rem;line-height:1.6;color:#666;margin:0 0 25px;min-height:60px}.play-button{background:#000;color:#fff;border:none;border-radius:8px;padding:12px 32px;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.play-button:hover{transform:scale(1.05);box-shadow:0 4px 15px #0000004d}.play-button:active{transform:scale(.98)}.footer{text-align:center;color:#999;font-size:.9rem;margin-top:auto}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@media(max-width:768px){.title{font-size:2.5rem}.subtitle{font-size:1.2rem}.games-grid{grid-template-columns:1fr;gap:20px}}.chess-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;background:#fff;padding:20px;gap:30px;position:relative;isolation:isolate;color:#333}.chess-container.dark{background:#0d101a;color:#f4f6ff}.theme-toggle{position:fixed;top:20px;right:20px;z-index:1000001;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 18px;font-size:14px;font-weight:600;border-radius:999px;border:1px solid #000;background:#000;color:#fff;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,background .2s ease}.theme-toggle:hover{transform:translateY(-2px);box-shadow:0 6px 20px #00000059}.chess-container.dark .theme-toggle{background:#f4f6ff;color:#111;border-color:#f4f6ff;box-shadow:none}.chess-container.dark .theme-toggle:hover{box-shadow:0 6px 20px #10142673}.setup-overlay{position:fixed;inset:0;background:#000000bf;display:grid;place-items:center;z-index:999999;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .28s ease-out,visibility 0s linear .28s}.setup-overlay.is-visible{opacity:1;visibility:visible;pointer-events:auto;transition-delay:0s,0s}.setup-modal{position:relative;background:#fff;padding:40px;border-radius:16px;box-shadow:0 25px 75px #0009;max-width:500px;width:90%;max-height:90vh;overflow-y:auto;opacity:0;transform:translate3d(0,-24px,0) scale(.94);transition:transform .32s cubic-bezier(.16,1,.3,1),opacity .22s ease-out;transform-origin:center;will-change:transform,opacity}.setup-modal.is-visible{opacity:1;transform:translateZ(0) scale(1)}.chess-container.dark .setup-modal{background:#151a2a;color:#f4f6ff;box-shadow:0 25px 75px #000000bf}.setup-modal h2{margin:0 0 30px;color:#333;font-size:28px;text-align:center}.chess-container.dark .setup-modal h2{color:#f4f6ff}.setup-option{margin-bottom:25px}.setup-option label{display:block;font-size:16px;font-weight:700;color:#555;margin-bottom:10px}.chess-container.dark .setup-option label{color:#d2d8f2}.color-selector,.game-type-selector{display:flex;gap:10px}.color-btn,.type-btn{flex:1;padding:15px 20px;font-size:16px;font-weight:500;border:2px solid #ddd;border-radius:8px;background:#fff;cursor:pointer;transition:all .2s ease}.chess-container.dark .color-btn,.chess-container.dark .type-btn{background:#12182b;border-color:#2b3350;color:#e2e6ff}.color-btn:hover,.type-btn:hover{border-color:#000;background:#f8f9ff;transform:translateY(-2px)}.chess-container.dark .color-btn:hover,.chess-container.dark .type-btn:hover{background:#1a2139;border-color:#404a6e}.color-btn.selected,.type-btn.selected{border-color:#000;background:#000;color:#fff}.setup-select{width:100%;padding:12px;font-size:16px;border:2px solid #ddd;border-radius:8px;cursor:pointer;transition:border-color .2s;background:#fff;color:#333}.setup-select:hover,.setup-select:focus{border-color:#000;outline:none}.chess-container.dark .setup-select{background:#12182b;border-color:#2b3350;color:#e2e6ff}.chess-container.dark .setup-select:hover,.chess-container.dark .setup-select:focus{border-color:#404a6e}.start-game-btn{width:100%;padding:16px;font-size:18px;font-weight:700;color:#fff;background:#000;border:none;border-radius:8px;cursor:pointer;margin-top:30px;transition:transform .2s,box-shadow .2s}.start-game-btn:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0006}.start-game-btn:active{transform:translateY(0)}.chess-container.dark .start-game-btn{background:#f4f6ff;color:#111;border-color:#f4f6ff}.chess-container.dark .start-game-btn:hover{box-shadow:0 8px 24px #0f13218c}.chess-controls{display:flex;flex-direction:column;align-items:center;gap:15px;background:#fff;padding:20px 40px;border-radius:12px;box-shadow:0 8px 16px #0003;width:100%;max-width:800px;height:240px}.chess-controls h1{margin:0;color:#333;font-size:32px}.player-info{font-size:16px;color:#555;padding:8px 16px;background:#f5f5f5;border-radius:6px;width:100%;text-align:center;height:40px;display:flex;align-items:center;justify-content:center}.turn-indicator{font-size:18px;font-weight:700;color:#fff;padding:10px 16px;background:#000;border-radius:8px;border:2px solid #000;width:100%;height:50px;display:flex;align-items:center;justify-content:center}.timer-display{display:flex;gap:15px;width:100%;justify-content:center}.timer{display:flex;flex-direction:column;align-items:center;padding:12px 20px;background:#f5f5f5;border-radius:8px;border:2px solid transparent;transition:all .3s ease;min-width:120px}.chess-container.dark .timer{background:#141a2b;border-color:#1f2538}.timer.active{border-color:#000;background:#000;box-shadow:0 4px 12px #0003}.timer.active .timer-label,.timer.active .timer-value{color:#fff}.timer-label{font-size:12px;font-weight:600;color:#777;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.chess-container.dark .timer-label{color:#c3cae9}.timer-value{font-size:28px;font-weight:700;font-family:Courier New,monospace;color:#333}.chess-container.dark .timer-value{color:#f4f6ff}.difficulty-selector{display:flex;align-items:center;gap:10px;width:100%;justify-content:center;height:45px}.difficulty-selector label{display:flex;align-items:center;gap:10px;font-weight:500;color:#555}.difficulty-selector select{padding:8px 12px;border:2px solid #ddd;border-radius:6px;font-size:14px;cursor:pointer;transition:border-color .3s}.difficulty-selector select:hover{border-color:#000}.chess-container.dark .difficulty-selector select{background:#12182b;border-color:#2b3350;color:#e2e6ff}.chess-container.dark .difficulty-selector select:hover{border-color:#404a6e}.thinking-indicator{color:#000;font-weight:700;font-size:16px;animation:pulse 1.5s ease-in-out infinite;height:30px;width:100%;display:flex;align-items:center;justify-content:center}.chess-container.dark .thinking-indicator{color:#f4f6ff}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.game-status-container{width:100%;height:50px;display:flex;align-items:center;justify-content:center}.game-status{font-size:20px;font-weight:700;color:#e74c3c;padding:10px 20px;background:#ffe5e5;border-radius:8px;display:flex;align-items:center;justify-content:center}.chess-container.dark .game-status{background:#421d1d;color:#ff9d9d}.new-game-btn{padding:12px 24px;font-size:16px;font-weight:700;color:#fff;background:#000;border:none;border-radius:8px;cursor:pointer;transition:transform .2s,box-shadow .2s;height:48px;width:auto}.new-game-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0006}.chess-container.dark .new-game-btn{background:#f4f6ff;color:#111;border-color:#f4f6ff}.chess-container.dark .new-game-btn:hover{box-shadow:0 4px 12px #0f132180}.game-board-container{display:flex;align-items:flex-end;gap:20px}.left-sidebar,.board-section{display:flex;flex-direction:column;gap:15px}.timer-box{background:#fff;padding:20px;border-radius:12px;box-shadow:0 8px 16px #0003;width:640px}.chess-container.dark .timer-box{background:#151a2a;box-shadow:0 8px 20px #00000073}.game-info-box{background:#fff;padding:15px;border-radius:8px;box-shadow:0 4px 12px #00000026;display:flex;flex-direction:column;gap:12px;width:120px}.chess-container.dark .game-info-box{background:#151a2a;box-shadow:0 6px 18px #0006}.info-row{display:flex;flex-direction:column;gap:4px}.info-label{font-size:11px;font-weight:600;color:#777;text-transform:uppercase;letter-spacing:.5px}.chess-container.dark .info-label{color:#b5bddf}.info-value{font-size:14px;font-weight:700;color:#333}.chess-container.dark .info-value{color:#f4f6ff}.new-game-btn-corner{padding:10px 20px;font-size:13px;font-weight:700;color:#fff;background:#000;border:none;border-radius:6px;cursor:pointer;transition:transform .2s,box-shadow .2s;width:100%;height:auto;margin-top:8px}.new-game-btn-corner:hover{transform:translateY(-2px);box-shadow:0 6px 16px #0006}.new-game-btn-corner:active{transform:translateY(0)}.chess-container.dark .new-game-btn-corner{background:#f4f6ff;color:#111;border-color:#f4f6ff}.chess-container.dark .new-game-btn-corner:hover{box-shadow:0 6px 16px #0f132173}.chessboard{display:flex;flex-direction:column;border:4px solid #333;border-radius:8px;overflow:hidden;box-shadow:0 10px 30px #0000004d;width:640px;height:640px;contain:layout style paint;transform:translateZ(0);backface-visibility:hidden}.captured-pieces{display:flex;flex-direction:column;gap:10px;background:#fff;padding:15px;border-radius:8px;box-shadow:0 4px 12px #00000026;width:120px;height:640px}.chess-container.dark .captured-pieces{background:#151a2a;box-shadow:0 6px 18px #0006}.captured-label{font-size:14px;font-weight:700;color:#555;text-align:center;padding-bottom:8px;border-bottom:2px solid #e0e0e0}.chess-container.dark .captured-label{color:#d2d8f2;border-bottom-color:#262c45}.captured-pieces-list{display:flex;flex-wrap:wrap;gap:4px;justify-content:center;align-content:flex-start;flex:1;overflow-y:auto}.chess-container.dark .captured-pieces-list{scrollbar-color:#2f3653 transparent}.captured-piece{width:32px;height:32px;opacity:.8;transition:opacity .2s ease-out;animation:capturedFadeIn .3s ease-out}.captured-piece:hover{opacity:1}@keyframes capturedFadeIn{0%{opacity:0;transform:scale(.5)}to{opacity:.8;transform:scale(1)}}.board-row{display:flex;flex-shrink:0}.square{width:80px;height:80px;min-width:80px;min-height:80px;display:flex;align-items:center;justify-content:center;cursor:pointer;position:relative;flex-shrink:0;padding:5px;box-sizing:border-box;transition:background-color .12s cubic-bezier(.4,0,.2,1)}.square.light{background-color:#f0d9b5}.square.dark{background-color:#b58863}.square:hover{filter:brightness(.9)}.square.selected{background-color:#baca44!important;box-shadow:inset 0 0 10px #0000004d}.square.legal-move{background-color:#baca4466!important}.chess-piece{width:70px;height:70px;pointer-events:none;-webkit-user-select:none;user-select:none;image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges}.move-indicator{position:absolute;width:20px;height:20px;background-color:#0000004d;border-radius:50%;pointer-events:none}.chess-container.dark .square:hover{filter:brightness(1.05)}@media(max-width:768px){.game-board-container{flex-direction:column;gap:15px}.captured-pieces{flex-direction:row;max-width:100%;width:100%}.captured-label{min-width:120px;border-bottom:none;border-right:2px solid #e0e0e0;padding-right:10px;padding-bottom:0}.captured-pieces-list{flex:1;justify-content:flex-start}.square{width:45px;height:45px;padding:2.5px}.chess-piece{width:40px;height:40px}.move-indicator{width:12px;height:12px}.captured-piece{width:24px;height:24px}}.game-page{position:relative;min-height:100vh}.back-button{position:fixed;top:20px;left:20px;padding:12px 24px;background:#fffffff2;color:#000;text-decoration:none;border-radius:8px;font-weight:600;box-shadow:0 2px 10px #0000001a;transition:transform .2s ease,box-shadow .2s ease;z-index:1000}.back-button:hover{transform:translateY(-2px);box-shadow:0 4px 15px #00000026}.back-button:active{transform:translateY(0)}.tic-tac-toe{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:30px;transition:background-color .3s ease}.tic-tac-toe.dark{background-color:#1a1a1a}.tic-tac-toe.dark .game-title{color:#f0f0f0;text-shadow:2px 2px 4px rgba(0,0,0,.5)}.tic-tac-toe.dark td{border:3px solid #444;background-color:#2a2a2a;color:#e0e0e0;box-shadow:0 2px 4px #0000004d}.tic-tac-toe.dark td:hover{background-color:#ffffff1a;transform:scale(1.02)}.tic-tac-toe.dark .theme-toggle{background-color:#333;color:#fff}.tic-tac-toe.dark .theme-toggle:hover{background-color:#444;transform:translateY(-2px);box-shadow:0 4px 8px #0000004d}.tic-tac-toe.dark .new-game-btn{background-color:#333;color:#fff;border:2px solid #444}.tic-tac-toe.dark .new-game-btn:hover{background-color:#444;transform:translateY(-2px);box-shadow:0 4px 12px #0006}.tic-tac-toe.light{background-color:#f5f5f5}.tic-tac-toe.light .game-title{color:#333;text-shadow:2px 2px 4px rgba(0,0,0,.1)}.tic-tac-toe.light td{border:3px solid #ccc;background-color:#fff;color:#333;box-shadow:0 2px 4px #0000001a}.tic-tac-toe.light td:hover{background-color:#0000000d;transform:scale(1.02)}.tic-tac-toe.light .theme-toggle{background-color:#fff;color:#333;border:2px solid #ccc}.tic-tac-toe.light .theme-toggle:hover{background-color:#f0f0f0;transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.tic-tac-toe.light .new-game-btn{background-color:#fff;color:#333;border:2px solid #ccc}.tic-tac-toe.light .new-game-btn:hover{background-color:#f0f0f0;transform:translateY(-2px);box-shadow:0 4px 12px #0003}.game-header{display:flex;align-items:center;gap:30px;margin-bottom:20px}.game-container{display:flex;flex-direction:column;align-items:center;gap:30px;position:relative}table{border-collapse:collapse;border-radius:12px;overflow:hidden}td{height:120px;width:120px;text-align:center;vertical-align:middle;font-family:Arial,sans-serif;font-size:80px;font-weight:700;cursor:pointer;transition:all .2s ease;-webkit-user-select:none;user-select:none}.endgame{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:linear-gradient(135deg,#2ecc71f2,#3498dbf2);padding:40px 60px;text-align:center;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;border-radius:16px;color:#fff;font-size:32px;font-weight:700;box-shadow:0 8px 24px #0000004d;border:3px solid rgba(255,255,255,.3);animation:fadeInScale .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);min-width:300px}@keyframes fadeInScale{0%{opacity:0;transform:translate(-50%,-50%) scale(.8)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.winning-cell{animation:winPulse .6s ease infinite alternate}@keyframes winPulse{0%{transform:scale(1);opacity:1}to{transform:scale(1.05);opacity:.9}}.new-game-btn{padding:14px 32px;font-size:18px;font-weight:600;border-radius:8px;cursor:pointer;transition:all .3s ease;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.new-game-btn:active{transform:translateY(0)}@media(max-width:768px){.game-title{font-size:32px}td{height:90px;width:90px;font-size:60px}.endgame{font-size:24px;padding:30px 40px;min-width:250px}.game-header{flex-direction:column;gap:15px}}.snake-game{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:20px;transition:background-color .3s ease}.snake-game.dark{background-color:#1a1a1a}.snake-game.dark canvas{border:2px solid #333;box-shadow:0 4px 6px #0000004d}.snake-game.dark .score-display{color:#ffce00;text-shadow:2px 2px 4px rgba(0,0,0,.5)}.snake-game.dark .controls-info{color:#999}.snake-game.light{background-color:#f5f5f5}.snake-game.light canvas{border:2px solid #ccc;box-shadow:0 4px 6px #0000001a}.snake-game.light .score-display{color:#e74c3c;text-shadow:2px 2px 4px rgba(0,0,0,.2)}.snake-game.light .controls-info{color:#666}canvas{border-radius:8px}.score-display{font-size:32px;font-weight:700}.controls-info{font-size:16px;font-style:italic}.snake-game.dark .theme-toggle{background-color:#333;color:#fff}.snake-game.dark .theme-toggle:hover{background-color:#444;transform:translateY(-2px);box-shadow:0 4px 8px #0000004d}.snake-game.light .theme-toggle{background-color:#fff;color:#333;border:2px solid #ccc}.snake-game.light .theme-toggle:hover{background-color:#f0f0f0;transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.space-invaders{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:20px;transition:background-color .3s ease;position:relative}.space-invaders.dark{background-color:#1a1a1a}.space-invaders.dark .game-title{color:#f0f0f0;text-shadow:2px 2px 4px rgba(0,0,0,.5)}.space-invaders.dark .game-canvas{border:2px solid #333;box-shadow:0 4px 6px #0000004d}.space-invaders.dark .controls-info{color:#999}.space-invaders.dark .theme-toggle{background-color:#333;color:#fff}.space-invaders.dark .theme-toggle:hover{background-color:#444;transform:translateY(-2px);box-shadow:0 4px 8px #0000004d}.space-invaders.light{background-color:#f5f5f5}.space-invaders.light .game-title{color:#333;text-shadow:2px 2px 4px rgba(0,0,0,.1)}.space-invaders.light .game-canvas{border:2px solid #ccc;box-shadow:0 4px 6px #0000001a}.space-invaders.light .controls-info{color:#666}.space-invaders.light .theme-toggle{background-color:#fff;color:#333;border:2px solid #ccc}.space-invaders.light .theme-toggle:hover{background-color:#f0f0f0;transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.game-header{display:flex;align-items:center;gap:30px}.game-title{font-size:42px;font-weight:700;margin:0;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.game-canvas{border-radius:8px;image-rendering:pixelated}.controls-info{font-size:16px;font-style:italic;text-align:center;line-height:1.6}.theme-toggle{padding:10px 20px;font-size:16px;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:all .3s ease}.theme-toggle:active{transform:translateY(0)}.game-over-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .3s ease}.game-over-message{background:linear-gradient(135deg,#1e1e1ef2,#505050f2);padding:50px 80px;border-radius:16px;text-align:center;color:#fff;font-size:48px;font-weight:700;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;box-shadow:0 10px 40px #00000080;animation:scaleIn .3s ease}.final-score{font-size:28px;margin:20px 0;opacity:.9}.restart-btn{margin-top:20px;padding:14px 32px;font-size:20px;font-weight:600;background:#fff;color:#333;border:none;border-radius:8px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #0003}.restart-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #0000004d}.restart-btn:active{transform:translateY(0)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{transform:scale(.8);opacity:0}to{transform:scale(1);opacity:1}}@media(max-width:768px){.game-title{font-size:32px}.game-canvas{max-width:100%;height:auto}.game-header{flex-direction:column;gap:15px}.game-over-message{font-size:32px;padding:40px 60px}.final-score{font-size:20px}}
