@import url(https://fonts.googleapis.com/css2?family=Cinzel+Decorative:wght@400;700;900&family=Playfair+Display:ital,wght@0,400;0,700;1,400&display=swap);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}.chess-title{background:linear-gradient(180deg,#f8e9a1 0,#c0b283 50%,#8b4513);-webkit-background-clip:text;background-clip:text;color:transparent;display:inline-block;font-family:Cinzel Decorative,serif;letter-spacing:1px;position:relative;text-shadow:2px 2px 4px rgba(0,0,0,.5),0 0 20px rgba(255,215,0,.8)}.chess-title:after{background:linear-gradient(90deg,transparent,#c0b283,transparent);bottom:-5px;content:"";height:2px;left:0;position:absolute;width:100%}:root{--vh:1vh}body,html{background:#000;height:100%;margin:0;overscroll-behavior:none;padding:0}.hourglass-cursor{cursor:wait}.Board{height:100%;text-align:center}.App-header,.Board{align-items:center;display:flex;flex-direction:column;justify-content:center}.App-header{width:100%}.piece{background-repeat:no-repeat;background-size:contain;display:block;height:35px;margin:3px;width:35px}@media (orientation:landscape){.piece{height:24px;margin:2px auto;width:24px}}.turn-legend{background-color:#fff;border:1px solid #ccc;border-radius:8px;color:#000;font-size:18px;padding:20px;text-align:center;width:200px}.piece-container{align-items:center;display:flex;flex-direction:row;height:44px;justify-content:center;margin:1px 3px;overflow:visible;width:44px}.piece-container-mobile{height:42px;width:42px}.piece-container-mobile,.piece-container-mobile-landscape{align-items:center;display:flex;flex-direction:row;justify-content:center;margin:2px;overflow:visible;position:relative}.piece-container-mobile-landscape{height:45px;width:45px}.piece-container-tablet{height:120px;margin:3px;overflow:visible;width:120px}.piece-container-compact,.piece-container-tablet{align-items:center;display:flex;flex-direction:row;justify-content:center;position:relative}.piece-container-compact{height:36px;margin:1px 2px;width:36px}.piece-count{align-items:center;background-color:#fff;border:1px solid #000;border-radius:50%;bottom:-10px;color:#000;display:flex;font-size:12px;font-weight:700;height:18px;justify-content:center;min-width:18px;position:absolute;right:-10px}@media (orientation:landscape) and (max-width:1024px){.piece-container{height:40px;margin:1px;width:40px}.piece-container-compact{height:45px;width:45px}.piece-container-mobile-landscape{height:45px!important;margin:2px!important;width:45px!important}.piece-count{bottom:-5px;font-size:8px;height:12px;min-width:12px;right:-5px}}.captured-pieces-legend{align-items:center;display:flex;flex-direction:row;flex-wrap:wrap;font-size:12px;gap:1px;justify-content:flex-start;margin:0;overflow-x:auto;padding:1px 2px;width:100%}.captured-pieces-legend-compact{padding:12px 0 20px}.captured-pieces-legend-compact,.captured-pieces-legend-mobile-portrait-top{align-items:flex-start;display:flex;flex-direction:row;flex-wrap:wrap;font-size:12px;gap:2px;height:100%;justify-content:flex-start;margin:0;overflow-x:auto;width:100%}.captured-pieces-legend-mobile-portrait-top{padding:8px 0 24px!important}.captured-pieces-legend-mobile-portrait-bottom{padding:8px 0 24px}.captured-pieces-legend-mobile-portrait-bottom,.captured-pieces-legend-tablet-portrait-top{align-items:flex-start;display:flex;flex-direction:row;flex-wrap:wrap;font-size:12px;gap:2px;height:100%;justify-content:flex-start;margin:0;overflow-x:auto;width:100%}.captured-pieces-legend-tablet-portrait-top{padding:18px 0 20px!important}@media (min-width:1300px){.captured-pieces-legend-tablet-portrait-top{padding:18px 0 40px!important}}.captured-pieces-legend-tablet-portrait-bottom{align-items:flex-start;display:flex;flex-direction:row;flex-wrap:wrap;font-size:12px;gap:2px;height:100%;justify-content:flex-start;margin:0;overflow-x:auto;padding:12px 0 18px;width:100%}.captured-pieces-legend-mobile-landscape{gap:2px;height:100%;padding:1px}.captured-pieces-legend-mobile-landscape,.captured-pieces-legend-mobile-landscape-compact{align-items:center;display:flex;flex-direction:column;font-size:10px;justify-content:flex-start;margin:0;overflow-y:auto;width:100%}.captured-pieces-legend-mobile-landscape-compact{gap:1px;max-height:100%;padding:2px 1px 14px}.captured-pieces-legend-tablet-landscape{gap:4px;height:100%}.captured-pieces-legend-tablet-landscape,.captured-pieces-legend-tablet-landscape-compact{align-items:center;display:flex;flex-direction:column;font-size:14px;justify-content:flex-start;margin:0;overflow-y:auto;padding:4px;width:100%}.captured-pieces-legend-tablet-landscape-compact{gap:3px;max-height:100%}.captured-pieces-legend-vertical{align-items:flex-start;display:flex;flex-direction:column;font-size:12px;height:auto;margin:1px;max-height:90vh;overflow-y:hidden;padding:1px;width:auto}.chess-landscape-container{display:flex!important;flex-direction:row!important;height:100%!important;max-height:-webkit-fill-available!important;min-height:100%!important;overflow:hidden!important;width:100%!important}.chess-landscape-legend{flex-direction:column!important;padding:0 8px!important;width:15%!important}.chess-landscape-board,.chess-landscape-legend{align-items:center!important;display:flex!important;height:100%!important;justify-content:center!important}.chess-landscape-board{position:relative!important}.chess-portrait-container{display:flex;flex-direction:column;height:100%;height:100vh;height:calc(var(--vh, 1vh)*100);justify-content:space-between;max-height:-webkit-fill-available;min-height:100%;overflow:hidden;padding:8px 8px 0}.chess-portrait-legend{align-items:center;display:flex;flex-shrink:0;height:50px;margin:5px 0;max-height:50px;min-height:50px;width:100%}.chess-portrait-board{align-items:center;display:flex;flex:1 0 auto;justify-content:center;margin:auto;min-height:0;position:relative;width:100%}@media (orientation:landscape) and (max-width:768px){.captured-pieces-legend{flex-direction:column;height:auto;width:100%}}@keyframes promotionGlow{0%{box-shadow:0 0 0 0 rgba(255,215,0,0);transform:scale(1)}20%{box-shadow:0 0 20px 10px rgba(255,215,0,.8);transform:scale(1.15)}40%{box-shadow:0 0 30px 15px rgba(255,215,0,.6);transform:scale(1.1)}60%{box-shadow:0 0 25px 12px rgba(255,215,0,.4);transform:scale(1.05)}80%{box-shadow:0 0 15px 8px rgba(255,215,0,.2);transform:scale(1.02)}to{box-shadow:0 0 0 0 rgba(255,215,0,0);transform:scale(1)}}@keyframes sparkle{0%,to{opacity:0;transform:scale(0) rotate(0deg)}50%{opacity:1;transform:scale(1) rotate(180deg)}}.promotion-animation{animation:promotionGlow 1.5s ease-out;position:relative;z-index:10}.promotion-animation:before{animation:sparkle 1s ease-out;left:5px;top:5px}.promotion-animation:after,.promotion-animation:before{content:"✨";font-size:24px;pointer-events:none;position:absolute;z-index:11}.promotion-animation:after{animation:sparkle 1s ease-out .3s;bottom:5px;right:5px}.castling-animation{animation:castlingGlow 1.5s ease-out;position:relative;z-index:10}@keyframes castlingGlow{0%{filter:drop-shadow(0 0 0 gold)}50%{filter:drop-shadow(0 0 15px gold)}to{filter:drop-shadow(0 0 0 gold)}}.castling-animation:before{animation:sparkle 1s ease-out;left:5px;top:5px}.castling-animation:after,.castling-animation:before{color:gold;content:"✨";font-size:24px;pointer-events:none;position:absolute;z-index:11}.castling-animation:after{animation:sparkle 1s ease-out .3s;bottom:5px;right:5px}