@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;-webkit-touch-callout:none;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0;user-select:none;-webkit-user-select:none}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%}@keyframes transporter-dematerialize{0%{filter:brightness(1) blur(0) saturate(1);opacity:1}18%{filter:brightness(1.35) blur(.4px) saturate(1.1);opacity:1}45%{filter:brightness(1.15) blur(.7px) saturate(1.05);opacity:.95}to{filter:brightness(.9) blur(1.6px) saturate(.9);opacity:0}}@keyframes transporter-sparkles{0%{opacity:0;transform:translateY(6%)}15%{opacity:.55}55%{opacity:.72}to{opacity:0;transform:translateY(-14%)}}@keyframes transporter-twinkle{0%{background-position:0 110%,18% 92%,36% 74%,54% 56%,72% 38%,90% 20%,10% 12%,62% 8%;opacity:0}12%{opacity:.45}22%{opacity:.25}34%{opacity:.62}46%{opacity:.3}58%{opacity:.7}72%{opacity:.3}88%{opacity:.5}to{background-position:0 -20%,18% 0,36% 20%,54% 40%,72% 60%,90% 80%,10% 70%,62% 55%;opacity:0}}@keyframes transporter-scanlines{0%{background-position:0 120%;opacity:0}10%{opacity:.55}55%{background-position:0 -20%;opacity:.35}to{background-position:0 -80%;opacity:0}}.dissolving-piece{animation:transporter-dematerialize 1.2s ease-out forwards;pointer-events:none;position:relative;will-change:opacity,filter}.dissolving-piece:before{animation:transporter-sparkles 1.2s ease-out forwards,transporter-twinkle 1.2s steps(10) forwards;background-image:radial-gradient(circle at 12% 18%,hsla(0,0%,100%,.75) 0 1px,hsla(0,0%,100%,0) 2px),radial-gradient(circle at 34% 16%,hsla(0,0%,100%,.65) 0 1px,hsla(0,0%,100%,0) 2px),radial-gradient(circle at 60% 22%,hsla(0,0%,100%,.7) 0 1px,hsla(0,0%,100%,0) 2px),radial-gradient(circle at 84% 14%,hsla(0,0%,100%,.68) 0 1px,hsla(0,0%,100%,0) 2px),radial-gradient(circle at 24% 36%,hsla(0,0%,100%,.62) 0 1px,hsla(0,0%,100%,0) 2px),radial-gradient(circle at 76% 38%,hsla(0,0%,100%,.6) 0 1px,hsla(0,0%,100%,0) 2px),radial-gradient(circle at 18% 56%,hsla(0,0%,100%,.7) 0 1px,hsla(0,0%,100%,0) 2px),radial-gradient(circle at 44% 70%,hsla(0,0%,100%,.6) 0 1px,hsla(0,0%,100%,0) 2px),radial-gradient(circle at 68% 76%,hsla(0,0%,100%,.72) 0 1px,hsla(0,0%,100%,0) 2px),radial-gradient(circle at 90% 58%,hsla(0,0%,100%,.58) 0 1px,hsla(0,0%,100%,0) 2px),radial-gradient(circle at 50% 48%,hsla(0,0%,100%,.8) 0 1px,hsla(0,0%,100%,0) 2px),radial-gradient(circle at 8% 82%,hsla(0,0%,100%,.65) 0 1px,hsla(0,0%,100%,0) 2px),radial-gradient(circle at 92% 84%,hsla(0,0%,100%,.7) 0 1px,hsla(0,0%,100%,0) 2px),radial-gradient(circle at 48% 8%,hsla(0,0%,100%,.75) 0 1px,hsla(0,0%,100%,0) 2px),radial-gradient(circle at 94% 32%,hsla(0,0%,100%,.6) 0 1px,hsla(0,0%,100%,0) 2px);background-repeat:repeat;background-size:30% 32%,34% 36%,28% 30%,36% 38%,28% 30%,32% 34%,34% 36%,38% 40%,30% 32%,36% 38%,32% 30%,36% 34%,30% 28%,34% 36%,28% 32%;filter:blur(.2px)}.dissolving-piece:after,.dissolving-piece:before{-webkit-clip-path:inset(0);clip-path:inset(0);content:"";inset:0;mix-blend-mode:screen;opacity:0;pointer-events:none;position:absolute}.dissolving-piece:after{animation:transporter-scanlines 1.2s ease-out forwards;background-image:repeating-linear-gradient(180deg,hsla(0,0%,100%,0) 0,hsla(0,0%,100%,.22) 1px,hsla(0,0%,100%,0) 4px);background-size:100% 140%}.dissolving-piece--3d:after,.dissolving-piece--3d:before{height:200%;height:var(--dissolve-height,200%);inset:auto 0 0 0}:root{--vh:1vh;--piece-3d-lift-scale:1;--piece-3d-lift-translate-y:-2px}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:-6px;color:#000;display:flex;font-size:13px;font-weight:700;height:20px;justify-content:center;min-width:20px;position:absolute;right:-6px}@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:-4px;font-size:10px;height:14px;min-width:14px;right:-4px}}.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:visible;padding:1px 2px;width:100%}.captured-pieces-legend-compact{overflow-x:auto;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;width:100%}.captured-pieces-legend-mobile-portrait-top{overflow:visible;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:visible;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:visible;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;height:auto;justify-content:flex-start;margin:0;overflow:visible;width:100%}.captured-pieces-legend-mobile-landscape-compact{gap:1px;max-height:none;padding:2px 1px 14px}.captured-pieces-legend-tablet-landscape{gap:4px}.captured-pieces-legend-tablet-landscape,.captured-pieces-legend-tablet-landscape-compact{align-items:center;display:flex;flex-direction:column;font-size:14px;height:auto;justify-content:flex-start;margin:0;overflow:visible;padding:4px;width:100%}.captured-pieces-legend-tablet-landscape-compact{gap:3px;max-height:none}.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:2px;top:2px}.castling-animation:after,.castling-animation:before{color:gold;content:"✨";font-size:34px;pointer-events:none;position:absolute;text-shadow:0 0 10px rgba(255,215,0,.9),0 0 18px rgba(255,215,0,.6);z-index:11}.castling-animation:after{animation:sparkle 1s ease-out .3s;bottom:2px;right:2px}@keyframes pop{0%{opacity:0;transform:scale(.8)}80%{opacity:1;transform:scale(1.1)}90%{opacity:1;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.piece-3d-hoverable{transition:z-index .05s linear}.piece-3d-hoverable img{transition:filter .15s ease-out}.piece-3d-hoverable.force-hover img,.piece-3d-hoverable:hover img{filter:drop-shadow(3px 8px 6px rgba(0,0,0,.5)) drop-shadow(0 0 10px rgba(255,255,255,.35)) drop-shadow(0 0 18px rgba(255,255,255,.2)) drop-shadow(0 0 0 rgba(0,0,0,0))!important;filter:drop-shadow(3px 8px 6px rgba(0,0,0,.5)) drop-shadow(0 0 10px rgba(255,255,255,.35)) drop-shadow(0 0 18px rgba(255,255,255,.2)) var(--piece-3d-extra-filter,drop-shadow(0 0 0 rgba(0,0,0,0)))!important}.piece-3d-hoverable-vintage img{transition:filter .15s ease-out}.piece-3d-hoverable-vintage.force-hover img,.piece-3d-hoverable-vintage:hover img{filter:drop-shadow(3px 8px 6px rgba(0,0,0,.5)) drop-shadow(0 0 10px rgba(255,255,255,.35)) drop-shadow(0 0 18px rgba(255,255,255,.2)) drop-shadow(0 0 0 rgba(0,0,0,0))!important;filter:drop-shadow(3px 8px 6px rgba(0,0,0,.5)) drop-shadow(0 0 10px rgba(255,255,255,.35)) drop-shadow(0 0 18px rgba(255,255,255,.2)) var(--piece-3d-extra-filter,drop-shadow(0 0 0 rgba(0,0,0,0)))!important}.piece-3d-hoverable:active{transform:none}@keyframes piece-3d-lift-move{0%{transform:translateZ(0)}15%{transform:translate3d(0,-2px,0);transform:translate3d(0,var(--piece-3d-lift-translate-y),0)}85%{transform:translate3d(0,-2px,0);transform:translate3d(0,var(--piece-3d-lift-translate-y),0)}to{transform:translateZ(0)}}.piece-3d-animating{animation:piece-3d-lift-move .4s ease-in-out;animation:piece-3d-lift-move var(--animation-duration,.4s) ease-in-out}.piece-3d-animating img{filter:drop-shadow(4px 10px 8px rgba(0,0,0,.55)) drop-shadow(0 0 0 rgba(0,0,0,0))!important;filter:drop-shadow(4px 10px 8px rgba(0,0,0,.55)) var(--piece-3d-extra-filter,drop-shadow(0 0 0 rgba(0,0,0,0)))!important}.piece-3d-drag img{filter:none!important;filter:var(--piece-3d-drag-filter,none)!important;mix-blend-mode:normal!important}.piece-3d-drag img,.piece-3d-move-overlay img{-webkit-backface-visibility:hidden;backface-visibility:hidden}.piece-3d-dragging-lift{transform:translate3d(0,-2px,0);transform:translate3d(0,var(--piece-3d-lift-translate-y),0)}.tablet-3d-no-callout{touch-action:none}.tablet-3d-no-callout,.tablet-3d-no-callout *{-webkit-touch-callout:none;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}.tablet-3d-no-callout img{-webkit-user-drag:none;user-drag:none}.react-clock{display:block;position:relative}.react-clock,.react-clock *,.react-clock :after,.react-clock :before{box-sizing:border-box}.react-clock__face{border:1px solid #000;border-radius:50%;bottom:0;left:0;position:absolute;right:0;top:0}.react-clock__hand{bottom:0;left:50%;position:absolute;right:50%;top:0}.react-clock__hand__body{background-color:#000;position:absolute;transform:translateX(-50%)}.react-clock__mark{bottom:0;left:50%;position:absolute;right:50%;top:0}.react-clock__mark__body{background-color:#000;position:absolute;transform:translateX(-50%)}.react-clock__mark__number{left:-40px;position:absolute;text-align:center;width:80px}.react-clock__second-hand__body{background-color:red}