.app{height:var(--app-height);display:flex;flex-direction:column;overflow:hidden;background:radial-gradient(circle at 10% 20%,rgba(212,175,55,.03) 0%,transparent 50%),radial-gradient(circle at 90% 80%,rgba(212,175,55,.02) 0%,transparent 50%),radial-gradient(circle at 40% 40%,rgba(212,175,55,.01) 0%,transparent 50%),var(--primary-bg)}.main{flex:1}.app-content{overflow:hidden;flex:1}.view-container{display:flex;width:200%;height:100%;transition:transform .6s cubic-bezier(.4,0,.2,1)}.view-container.list{transform:translate(0)}.view-container.game{transform:translate(-50%)}.list-view,.game-view{width:50%;height:100%;overflow-x:hidden;min-height:0}.list-view{overflow-y:auto;direction:ltr}.game-view{overflow-y:hidden}.cg-wrap{box-sizing:content-box;position:relative;display:block}cg-container{position:absolute;width:100%;height:100%;display:block;top:0}cg-board{position:absolute;top:0;left:0;width:100%;height:100%;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;line-height:0;background-size:cover}.cg-wrap.manipulable cg-board{cursor:pointer}cg-board square{position:absolute;top:0;left:0;width:12.5%;height:12.5%;pointer-events:none}cg-board square.move-dest{pointer-events:auto}cg-board square.last-move{will-change:transform}.cg-wrap piece{position:absolute;top:0;left:0;width:12.5%;height:12.5%;background-size:cover;z-index:2;will-change:transform;pointer-events:none}cg-board piece.dragging{cursor:move;z-index:11!important}piece.anim{z-index:8}piece.fading{z-index:1;opacity:.5}.cg-wrap piece.ghost{opacity:.3}.cg-wrap piece svg{overflow:hidden;position:relative;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:2;opacity:.6}.cg-wrap cg-auto-pieces,.cg-wrap .cg-shapes,.cg-wrap .cg-custom-svgs{overflow:visible;position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none}.cg-wrap cg-auto-pieces{z-index:2}.cg-wrap cg-auto-pieces piece{opacity:.3}.cg-wrap .cg-shapes{overflow:hidden;opacity:.6;z-index:2}.cg-wrap .cg-custom-svgs{z-index:9}.cg-wrap .cg-custom-svgs svg{overflow:visible}.cg-wrap coords{position:absolute;display:flex;pointer-events:none;opacity:.8;font-family:sans-serif;font-size:9px}.cg-wrap coords.ranks{left:4px;top:-20px;flex-flow:column-reverse;height:100%;width:12px}.cg-wrap coords.ranks.black{flex-flow:column}.cg-wrap coords.ranks.left{left:-15px;align-items:flex-end}.cg-wrap coords.files{bottom:-4px;left:24px;flex-flow:row;width:100%;height:16px;text-transform:uppercase;text-align:center}.cg-wrap coords.files.black{flex-flow:row-reverse}.cg-wrap coords coord{flex:1 1 auto}.cg-wrap coords.ranks coord{transform:translateY(39%)}cg-board{background-color:#f0d9b5;background-image:url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiIHN0YW5kYWxvbmU9Im5vIj8+CjxzdmcgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB4bWxuczp4PSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hsaW5rIgogICAgIHZpZXdCb3g9IjAgMCA4IDgiIHNoYXBlLXJlbmRlcmluZz0iY3Jpc3BFZGdlcyI+CjxnIGlkPSJhIj4KICA8ZyBpZD0iYiI+CiAgICA8ZyBpZD0iYyI+CiAgICAgIDxnIGlkPSJkIj4KICAgICAgICA8cmVjdCB3aWR0aD0iMSIgaGVpZ2h0PSIxIiBpZD0iZSIgb3BhY2l0eT0iMCIvPgogICAgICAgIDx1c2UgeD0iMSIgeT0iMSIgaHJlZj0iI2UiIHg6aHJlZj0iI2UiLz4KICAgICAgICA8cmVjdCB5PSIxIiB3aWR0aD0iMSIgaGVpZ2h0PSIxIiBpZD0iZiIgb3BhY2l0eT0iMC4yIi8+CiAgICAgICAgPHVzZSB4PSIxIiB5PSItMSIgaHJlZj0iI2YiIHg6aHJlZj0iI2YiLz4KICAgICAgPC9nPgogICAgICA8dXNlIHg9IjIiIGhyZWY9IiNkIiB4OmhyZWY9IiNkIi8+CiAgICA8L2c+CiAgICA8dXNlIHg9IjQiIGhyZWY9IiNjIiB4OmhyZWY9IiNjIi8+CiAgPC9nPgogIDx1c2UgeT0iMiIgaHJlZj0iI2IiIHg6aHJlZj0iI2IiLz4KPC9nPgo8dXNlIHk9IjQiIGhyZWY9IiNhIiB4OmhyZWY9IiNhIi8+Cjwvc3ZnPg==)}cg-board square.move-dest{background:radial-gradient(#14551e80 22%,#208530 0,#0000004d,#0000 0)}cg-board square.premove-dest{background:radial-gradient(#141e5580 22%,#203085 0,#0000004d,#0000 0)}cg-board square.oc.move-dest{background:radial-gradient(transparent 0%,transparent 80%,rgba(20,85,0,.3) 80%)}cg-board square.oc.premove-dest{background:radial-gradient(transparent 0%,transparent 80%,rgba(20,30,85,.2) 80%)}cg-board square.move-dest:hover{background:#14551e4d}cg-board square.premove-dest:hover{background:#141e5533}cg-board square.last-move{background-color:#d4af3769}cg-board square.selected{background-color:#14551e80}cg-board square.check:after{content:"";position:absolute;top:50%;left:50%;width:40%;height:40%;background:radial-gradient(circle,rgba(255,80,80,.8) 0%,transparent 70%);border-radius:50%;transform:translate(-50%,-50%);animation:checkPulse 2s ease-in-out infinite;pointer-events:none;z-index:0}@keyframes checkPulse{0%,to{transform:translate(-50%,-50%) scale(2.5);opacity:1}50%{transform:translate(-50%,-50%) scale(3);opacity:1}}cg-board square.current-premove{background-color:#141e5580}.cg-wrap.orientation-white coords.ranks coord:nth-child(2n),.cg-wrap.orientation-white coords.files coord:nth-child(2n),.cg-wrap.orientation-black coords.ranks coord:nth-child(odd),.cg-wrap.orientation-black coords.files coord:nth-child(odd){color:#484848cc}.cg-wrap.orientation-black coords.ranks coord:nth-child(2n),.cg-wrap.orientation-black coords.files coord:nth-child(2n),.cg-wrap.orientation-white coords.ranks coord:nth-child(odd),.cg-wrap.orientation-white coords.files coord:nth-child(odd){color:#fffc}.cg-wrap piece.pawn.white{background-image:url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSI0NSIgaGVpZ2h0PSI0NSI+PHBhdGggZD0iTTIyLjUgOWMtMi4yMSAwLTQgMS43OS00IDQgMCAuODkuMjkgMS43MS43OCAyLjM4QzE3LjMzIDE2LjUgMTYgMTguNTkgMTYgMjFjMCAyLjAzLjk0IDMuODQgMi40MSA1LjAzLTMgMS4wNi03LjQxIDUuNTUtNy40MSAxMy40N2gyM2MwLTcuOTItNC40MS0xMi40MS03LjQxLTEzLjQ3IDEuNDctMS4xOSAyLjQxLTMgMi40MS01LjAzIDAtMi40MS0xLjMzLTQuNS0zLjI4LTUuNjIuNDktLjY3Ljc4LTEuNDkuNzgtMi4zOCAwLTIuMjEtMS43OS00LTQtNHoiIGZpbGw9IiNmZmYiIHN0cm9rZT0iIzAwMCIgc3Ryb2tlLXdpZHRoPSIxLjUiIHN0cm9rZS1saW5lY2FwPSJyb3VuZCIvPjwvc3ZnPg==)}.cg-wrap piece.bishop.white{background-image:url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSI0NSIgaGVpZ2h0PSI0NSI+PGcgZmlsbD0ibm9uZSIgZmlsbC1ydWxlPSJldmVub2RkIiBzdHJva2U9IiMwMDAiIHN0cm9rZS13aWR0aD0iMS41IiBzdHJva2UtbGluZWNhcD0icm91bmQiIHN0cm9rZS1saW5lam9pbj0icm91bmQiPjxnIGZpbGw9IiNmZmYiIHN0cm9rZS1saW5lY2FwPSJidXR0Ij48cGF0aCBkPSJNOSAzNmMzLjM5LS45NyAxMC4xMS40MyAxMy41LTIgMy4zOSAyLjQzIDEwLjExIDEuMDMgMTMuNSAyIDAgMCAxLjY1LjU0IDMgMi0uNjguOTctMS42NS45OS0zIC41LTMuMzktLjk3LTEwLjExLjQ2LTEzLjUtMS0zLjM5IDEuNDYtMTAuMTEuMDMtMTMuNSAxLTEuMzU0LjQ5LTIuMzIzLjQ3LTMtLjUgMS4zNTQtMS45NCAzLTIgMy0yeiIvPjxwYXRoIGQ9Ik0xNSAzMmMyLjUgMi41IDEyLjUgMi41IDE1IDAgLjUtMS41IDAtMiAwLTIgMC0yLjUtMi41LTQtMi41LTQgNS41LTEuNSA2LTExLjUtNS0xNS41LTExIDQtMTAuNSAxNC01IDE1LjUgMCAwLTIuNSAxLjUtMi41IDQgMCAwLS41LjUgMCAyeiIvPjxwYXRoIGQ9Ik0yNSA4YTIuNSAyLjUgMCAxIDEtNSAwIDIuNSAyLjUgMCAxIDEgNSAweiIvPjwvZz48cGF0aCBkPSJNMTcuNSAyNmgxME0xNSAzMGgxNW0tNy41LTE0LjV2NU0yMCAxOGg1IiBzdHJva2UtbGluZWpvaW49Im1pdGVyIi8+PC9nPjwvc3ZnPg==)}.cg-wrap piece.knight.white{background-image:url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSI0NSIgaGVpZ2h0PSI0NSI+PGcgZmlsbD0ibm9uZSIgZmlsbC1ydWxlPSJldmVub2RkIiBzdHJva2U9IiMwMDAiIHN0cm9rZS13aWR0aD0iMS41IiBzdHJva2UtbGluZWNhcD0icm91bmQiIHN0cm9rZS1saW5lam9pbj0icm91bmQiPjxwYXRoIGQ9Ik0yMiAxMGMxMC41IDEgMTYuNSA4IDE2IDI5SDE1YzAtOSAxMC02LjUgOC0yMSIgZmlsbD0iI2ZmZiIvPjxwYXRoIGQ9Ik0yNCAxOGMuMzggMi45MS01LjU1IDcuMzctOCA5LTMgMi0yLjgyIDQuMzQtNSA0LTEuMDQyLS45NCAxLjQxLTMuMDQgMC0zLTEgMCAuMTkgMS4yMy0xIDItMSAwLTQuMDAzIDEtNC00IDAtMiA2LTEyIDYtMTJzMS44OS0xLjkgMi0zLjVjLS43My0uOTk0LS41LTItLjUtMyAxLTEgMyAyLjUgMyAyLjVoMnMuNzgtMS45OTIgMi41LTNjMSAwIDEgMyAxIDMiIGZpbGw9IiNmZmYiLz48cGF0aCBkPSJNOS41IDI1LjVhLjUuNSAwIDEgMS0xIDAgLjUuNSAwIDEgMSAxIDB6bTUuNDMzLTkuNzVhLjUgMS41IDMwIDEgMS0uODY2LS41LjUgMS41IDMwIDEgMSAuODY2LjV6IiBmaWxsPSIjMDAwIi8+PC9nPjwvc3ZnPg==)}.cg-wrap piece.rook.white{background-image:url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSI0NSIgaGVpZ2h0PSI0NSI+PGcgZmlsbD0iI2ZmZiIgZmlsbC1ydWxlPSJldmVub2RkIiBzdHJva2U9IiMwMDAiIHN0cm9rZS13aWR0aD0iMS41IiBzdHJva2UtbGluZWNhcD0icm91bmQiIHN0cm9rZS1saW5lam9pbj0icm91bmQiPjxwYXRoIGQ9Ik05IDM5aDI3di0zSDl2M3ptMy0zdi00aDIxdjRIMTJ6bS0xLTIyVjloNHYyaDVWOWg1djJoNVY5aDR2NSIgc3Ryb2tlLWxpbmVjYXA9ImJ1dHQiLz48cGF0aCBkPSJNMzQgMTRsLTMgM0gxNGwtMy0zIi8+PHBhdGggZD0iTTMxIDE3djEyLjVIMTRWMTciIHN0cm9rZS1saW5lY2FwPSJidXR0IiBzdHJva2UtbGluZWpvaW49Im1pdGVyIi8+PHBhdGggZD0iTTMxIDI5LjVsMS41IDIuNWgtMjBsMS41LTIuNSIvPjxwYXRoIGQ9Ik0xMSAxNGgyMyIgZmlsbD0ibm9uZSIgc3Ryb2tlLWxpbmVqb2luPSJtaXRlciIvPjwvZz48L3N2Zz4=)}.cg-wrap piece.queen.white{background-image:url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSI0NSIgaGVpZ2h0PSI0NSI+PGcgZmlsbD0iI2ZmZiIgZmlsbC1ydWxlPSJldmVub2RkIiBzdHJva2U9IiMwMDAiIHN0cm9rZS13aWR0aD0iMS41IiBzdHJva2UtbGluZWNhcD0icm91bmQiIHN0cm9rZS1saW5lam9pbj0icm91bmQiPjxwYXRoIGQ9Ik04IDEyYTIgMiAwIDEgMS00IDAgMiAyIDAgMSAxIDQgMHptMTYuNS00LjVhMiAyIDAgMSAxLTQgMCAyIDIgMCAxIDEgNCAwek00MSAxMmEyIDIgMCAxIDEtNCAwIDIgMiAwIDEgMSA0IDB6TTE2IDguNWEyIDIgMCAxIDEtNCAwIDIgMiAwIDEgMSA0IDB6TTMzIDlhMiAyIDAgMSAxLTQgMCAyIDIgMCAxIDEgNCAweiIvPjxwYXRoIGQ9Ik05IDI2YzguNS0xLjUgMjEtMS41IDI3IDBsMi0xMi03IDExVjExbC01LjUgMTMuNS0zLTE1LTMgMTUtNS41LTE0VjI1TDcgMTRsMiAxMnoiIHN0cm9rZS1saW5lY2FwPSJidXR0Ii8+PHBhdGggZD0iTTkgMjZjMCAyIDEuNSAyIDIuNSA0IDEgMS41IDEgMSAuNSAzLjUtMS41IDEtMS41IDIuNS0xLjUgMi41LTEuNSAxLjUuNSAyLjUuNSAyLjUgNi41IDEgMTYuNSAxIDIzIDAgMCAwIDEuNS0xIDAtMi41IDAgMCAuNS0xLjUtMS0yLjUtLjUtMi41LS41LTIgLjUtMy41IDEtMiAyLjUtMiAyLjUtNC04LjUtMS41LTE4LjUtMS41LTI3IDB6IiBzdHJva2UtbGluZWNhcD0iYnV0dCIvPjxwYXRoIGQ9Ik0xMS41IDMwYzMuNS0xIDE4LjUtMSAyMiAwTTEyIDMzLjVjNi0xIDE1LTEgMjEgMCIgZmlsbD0ibm9uZSIvPjwvZz48L3N2Zz4=)}.cg-wrap piece.king.white{background-image:url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSI0NSIgaGVpZ2h0PSI0NSI+PGcgZmlsbD0ibm9uZSIgZmlsbC1ydWxlPSJldmVub2RkIiBzdHJva2U9IiMwMDAiIHN0cm9rZS13aWR0aD0iMS41IiBzdHJva2UtbGluZWNhcD0icm91bmQiIHN0cm9rZS1saW5lam9pbj0icm91bmQiPjxwYXRoIGQ9Ik0yMi41IDExLjYzVjZNMjAgOGg1IiBzdHJva2UtbGluZWpvaW49Im1pdGVyIi8+PHBhdGggZD0iTTIyLjUgMjVzNC41LTcuNSAzLTEwLjVjMCAwLTEtMi41LTMtMi41cy0zIDIuNS0zIDIuNWMtMS41IDMgMyAxMC41IDMgMTAuNSIgZmlsbD0iI2ZmZiIgc3Ryb2tlLWxpbmVjYXA9ImJ1dHQiIHN0cm9rZS1saW5lam9pbj0ibWl0ZXIiLz48cGF0aCBkPSJNMTEuNSAzN2M1LjUgMy41IDE1LjUgMy41IDIxIDB2LTdzOS00LjUgNi0xMC41Yy00LTYuNS0xMy41LTMuNS0xNiA0VjI3di0zLjVjLTMuNS03LjUtMTMtMTAuNS0xNi00LTMgNiA1IDEwIDUgMTBWMzd6IiBmaWxsPSIjZmZmIi8+PHBhdGggZD0iTTExLjUgMzBjNS41LTMgMTUuNS0zIDIxIDBtLTIxIDMuNWM1LjUtMyAxNS41LTMgMjEgMG0tMjEgMy41YzUuNS0zIDE1LjUtMyAyMSAwIi8+PC9nPjwvc3ZnPg==)}.cg-wrap piece.pawn.black{background-image:url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSI0NSIgaGVpZ2h0PSI0NSI+PHBhdGggZD0iTTIyLjUgOWMtMi4yMSAwLTQgMS43OS00IDQgMCAuODkuMjkgMS43MS43OCAyLjM4QzE3LjMzIDE2LjUgMTYgMTguNTkgMTYgMjFjMCAyLjAzLjk0IDMuODQgMi40MSA1LjAzLTMgMS4wNi03LjQxIDUuNTUtNy40MSAxMy40N2gyM2MwLTcuOTItNC40MS0xMi40MS03LjQxLTEzLjQ3IDEuNDctMS4xOSAyLjQxLTMgMi40MS01LjAzIDAtMi40MS0xLjMzLTQuNS0zLjI4LTUuNjIuNDktLjY3Ljc4LTEuNDkuNzgtMi4zOCAwLTIuMjEtMS43OS00LTQtNHoiIHN0cm9rZT0iIzAwMCIgc3Ryb2tlLXdpZHRoPSIxLjUiIHN0cm9rZS1saW5lY2FwPSJyb3VuZCIvPjwvc3ZnPg==)}.cg-wrap piece.bishop.black{background-image:url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSI0NSIgaGVpZ2h0PSI0NSI+PGcgZmlsbD0ibm9uZSIgZmlsbC1ydWxlPSJldmVub2RkIiBzdHJva2U9IiMwMDAiIHN0cm9rZS13aWR0aD0iMS41IiBzdHJva2UtbGluZWNhcD0icm91bmQiIHN0cm9rZS1saW5lam9pbj0icm91bmQiPjxnIGZpbGw9IiMwMDAiIHN0cm9rZS1saW5lY2FwPSJidXR0Ij48cGF0aCBkPSJNOSAzNmMzLjM5LS45NyAxMC4xMS40MyAxMy41LTIgMy4zOSAyLjQzIDEwLjExIDEuMDMgMTMuNSAyIDAgMCAxLjY1LjU0IDMgMi0uNjguOTctMS42NS45OS0zIC41LTMuMzktLjk3LTEwLjExLjQ2LTEzLjUtMS0zLjM5IDEuNDYtMTAuMTEuMDMtMTMuNSAxLTEuMzU0LjQ5LTIuMzIzLjQ3LTMtLjUgMS4zNTQtMS45NCAzLTIgMy0yeiIvPjxwYXRoIGQ9Ik0xNSAzMmMyLjUgMi41IDEyLjUgMi41IDE1IDAgLjUtMS41IDAtMiAwLTIgMC0yLjUtMi41LTQtMi41LTQgNS41LTEuNSA2LTExLjUtNS0xNS41LTExIDQtMTAuNSAxNC01IDE1LjUgMCAwLTIuNSAxLjUtMi41IDQgMCAwLS41LjUgMCAyeiIvPjxwYXRoIGQ9Ik0yNSA4YTIuNSAyLjUgMCAxIDEtNSAwIDIuNSAyLjUgMCAxIDEgNSAweiIvPjwvZz48cGF0aCBkPSJNMTcuNSAyNmgxME0xNSAzMGgxNW0tNy41LTE0LjV2NU0yMCAxOGg1IiBzdHJva2U9IiNlY2VjZWMiIHN0cm9rZS1saW5lam9pbj0ibWl0ZXIiLz48L2c+PC9zdmc+)}.cg-wrap piece.knight.black{background-image:url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSI0NSIgaGVpZ2h0PSI0NSI+PGcgZmlsbD0ibm9uZSIgZmlsbC1ydWxlPSJldmVub2RkIiBzdHJva2U9IiMwMDAiIHN0cm9rZS13aWR0aD0iMS41IiBzdHJva2UtbGluZWNhcD0icm91bmQiIHN0cm9rZS1saW5lam9pbj0icm91bmQiPjxwYXRoIGQ9Ik0yMiAxMGMxMC41IDEgMTYuNSA4IDE2IDI5SDE1YzAtOSAxMC02LjUgOC0yMSIgZmlsbD0iIzAwMCIvPjxwYXRoIGQ9Ik0yNCAxOGMuMzggMi45MS01LjU1IDcuMzctOCA5LTMgMi0yLjgyIDQuMzQtNSA0LTEuMDQyLS45NCAxLjQxLTMuMDQgMC0zLTEgMCAuMTkgMS4yMy0xIDItMSAwLTQuMDAzIDEtNC00IDAtMiA2LTEyIDYtMTJzMS44OS0xLjkgMi0zLjVjLS43My0uOTk0LS41LTItLjUtMyAxLTEgMyAyLjUgMyAyLjVoMnMuNzgtMS45OTIgMi41LTNjMSAwIDEgMyAxIDMiIGZpbGw9IiMwMDAiLz48cGF0aCBkPSJNOS41IDI1LjVhLjUuNSAwIDEgMS0xIDAgLjUuNSAwIDEgMSAxIDB6bTUuNDMzLTkuNzVhLjUgMS41IDMwIDEgMS0uODY2LS41LjUgMS41IDMwIDEgMSAuODY2LjV6IiBmaWxsPSIjZWNlY2VjIiBzdHJva2U9IiNlY2VjZWMiLz48cGF0aCBkPSJNMjQuNTUgMTAuNGwtLjQ1IDEuNDUuNS4xNWMzLjE1IDEgNS42NSAyLjQ5IDcuOSA2Ljc1UzM1Ljc1IDI5LjA2IDM1LjI1IDM5bC0uMDUuNWgyLjI1bC4wNS0uNWMuNS0xMC4wNi0uODgtMTYuODUtMy4yNS0yMS4zNC0yLjM3LTQuNDktNS43OS02LjY0LTkuMTktNy4xNmwtLjUxLS4xeiIgZmlsbD0iI2VjZWNlYyIgc3Ryb2tlPSJub25lIi8+PC9nPjwvc3ZnPg==)}.cg-wrap piece.rook.black{background-image:url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSI0NSIgaGVpZ2h0PSI0NSI+PGcgZmlsbC1ydWxlPSJldmVub2RkIiBzdHJva2U9IiMwMDAiIHN0cm9rZS13aWR0aD0iMS41IiBzdHJva2UtbGluZWNhcD0icm91bmQiIHN0cm9rZS1saW5lam9pbj0icm91bmQiPjxwYXRoIGQ9Ik05IDM5aDI3di0zSDl2M3ptMy41LTdsMS41LTIuNWgxN2wxLjUgMi41aC0yMHptLS41IDR2LTRoMjF2NEgxMnoiIHN0cm9rZS1saW5lY2FwPSJidXR0Ii8+PHBhdGggZD0iTTE0IDI5LjV2LTEzaDE3djEzSDE0eiIgc3Ryb2tlLWxpbmVjYXA9ImJ1dHQiIHN0cm9rZS1saW5lam9pbj0ibWl0ZXIiLz48cGF0aCBkPSJNMTQgMTYuNUwxMSAxNGgyM2wtMyAyLjVIMTR6TTExIDE0VjloNHYyaDVWOWg1djJoNVY5aDR2NUgxMXoiIHN0cm9rZS1saW5lY2FwPSJidXR0Ii8+PHBhdGggZD0iTTEyIDM1LjVoMjFtLTIwLTRoMTltLTE4LTJoMTdtLTE3LTEzaDE3TTExIDE0aDIzIiBmaWxsPSJub25lIiBzdHJva2U9IiNlY2VjZWMiIHN0cm9rZS13aWR0aD0iMSIgc3Ryb2tlLWxpbmVqb2luPSJtaXRlciIvPjwvZz48L3N2Zz4=)}.cg-wrap piece.queen.black{background-image:url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSI0NSIgaGVpZ2h0PSI0NSI+PGcgZmlsbC1ydWxlPSJldmVub2RkIiBzdHJva2U9IiMwMDAiIHN0cm9rZS13aWR0aD0iMS41IiBzdHJva2UtbGluZWNhcD0icm91bmQiIHN0cm9rZS1saW5lam9pbj0icm91bmQiPjxnIHN0cm9rZT0ibm9uZSI+PGNpcmNsZSBjeD0iNiIgY3k9IjEyIiByPSIyLjc1Ii8+PGNpcmNsZSBjeD0iMTQiIGN5PSI5IiByPSIyLjc1Ii8+PGNpcmNsZSBjeD0iMjIuNSIgY3k9IjgiIHI9IjIuNzUiLz48Y2lyY2xlIGN4PSIzMSIgY3k9IjkiIHI9IjIuNzUiLz48Y2lyY2xlIGN4PSIzOSIgY3k9IjEyIiByPSIyLjc1Ii8+PC9nPjxwYXRoIGQ9Ik05IDI2YzguNS0xLjUgMjEtMS41IDI3IDBsMi41LTEyLjVMMzEgMjVsLS4zLTE0LjEtNS4yIDEzLjYtMy0xNC41LTMgMTQuNS01LjItMTMuNkwxNCAyNSA2LjUgMTMuNSA5IDI2eiIgc3Ryb2tlLWxpbmVjYXA9ImJ1dHQiLz48cGF0aCBkPSJNOSAyNmMwIDIgMS41IDIgMi41IDQgMSAxLjUgMSAxIC41IDMuNS0xLjUgMS0xLjUgMi41LTEuNSAyLjUtMS41IDEuNS41IDIuNS41IDIuNSA2LjUgMSAxNi41IDEgMjMgMCAwIDAgMS41LTEgMC0yLjUgMCAwIC41LTEuNS0xLTIuNS0uNS0yLjUtLjUtMiAuNS0zLjUgMS0yIDIuNS0yIDIuNS00LTguNS0xLjUtMTguNS0xLjUtMjcgMHoiIHN0cm9rZS1saW5lY2FwPSJidXR0Ii8+PHBhdGggZD0iTTExIDM4LjVhMzUgMzUgMSAwIDAgMjMgMCIgZmlsbD0ibm9uZSIgc3Ryb2tlLWxpbmVjYXA9ImJ1dHQiLz48cGF0aCBkPSJNMTEgMjlhMzUgMzUgMSAwIDEgMjMgMG0tMjEuNSAyLjVoMjBtLTIxIDNhMzUgMzUgMSAwIDAgMjIgMG0tMjMgM2EzNSAzNSAxIDAgMCAyNCAwIiBmaWxsPSJub25lIiBzdHJva2U9IiNlY2VjZWMiLz48L2c+PC9zdmc+)}.cg-wrap piece.king.black{background-image:url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSI0NSIgaGVpZ2h0PSI0NSI+PGcgZmlsbD0ibm9uZSIgZmlsbC1ydWxlPSJldmVub2RkIiBzdHJva2U9IiMwMDAiIHN0cm9rZS13aWR0aD0iMS41IiBzdHJva2UtbGluZWNhcD0icm91bmQiIHN0cm9rZS1saW5lam9pbj0icm91bmQiPjxwYXRoIGQ9Ik0yMi41IDExLjYzVjYiIHN0cm9rZS1saW5lam9pbj0ibWl0ZXIiLz48cGF0aCBkPSJNMjIuNSAyNXM0LjUtNy41IDMtMTAuNWMwIDAtMS0yLjUtMy0yLjVzLTMgMi41LTMgMi41Yy0xLjUgMyAzIDEwLjUgMyAxMC41IiBmaWxsPSIjMDAwIiBzdHJva2UtbGluZWNhcD0iYnV0dCIgc3Ryb2tlLWxpbmVqb2luPSJtaXRlciIvPjxwYXRoIGQ9Ik0xMS41IDM3YzUuNSAzLjUgMTUuNSAzLjUgMjEgMHYtN3M5LTQuNSA2LTEwLjVjLTQtNi41LTEzLjUtMy41LTE2IDRWMjd2LTMuNWMtMy41LTcuNS0xMy0xMC41LTE2LTQtMyA2IDUgMTAgNSAxMFYzN3oiIGZpbGw9IiMwMDAiLz48cGF0aCBkPSJNMjAgOGg1IiBzdHJva2UtbGluZWpvaW49Im1pdGVyIi8+PHBhdGggZD0iTTMyIDI5LjVzOC41LTQgNi4wMy05LjY1QzM0LjE1IDE0IDI1IDE4IDIyLjUgMjQuNWwuMDEgMi4xLS4wMS0yLjFDMjAgMTggOS45MDYgMTQgNi45OTcgMTkuODVjLTIuNDk3IDUuNjUgNC44NTMgOSA0Ljg1MyA5IiBzdHJva2U9IiNlY2VjZWMiLz48cGF0aCBkPSJNMTEuNSAzMGM1LjUtMyAxNS41LTMgMjEgMG0tMjEgMy41YzUuNS0zIDE1LjUtMyAyMSAwbS0yMSAzLjVjNS41LTMgMTUuNS0zIDIxIDAiIHN0cm9rZT0iI2VjZWNlYyIvPjwvZz48L3N2Zz4=)}:root{--primary-bg: #0a0a0a;--secondary-bg: #1a1a1a;--gold: #d4af37;--gold-hover: #f0c649;--gold-muted: rgba(212, 175, 55, .6);--text-primary: #ffffff;--text-secondary: #cccccc;--text-muted: #888888;--border: rgba(255, 255, 255, .1);--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--radius-sm: .25rem;--radius-md: .5rem;--radius-lg: .75rem;--shadow-medium: 0 4px 6px -1px rgba(0, 0, 0, .3), 0 2px 4px -1px rgba(0, 0, 0, .2);--font-display: "Playfair Display", serif;--font-body: "Inter", sans-serif}*{margin:0;padding:0;box-sizing:border-box}html{height:100%}body{font-family:var(--font-body);line-height:1.5;background:var(--primary-bg);color:var(--text-primary);height:100%;overflow:hidden}body:before{content:"";position:fixed;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at 20% 50%,rgba(212,175,55,.02) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(212,175,55,.03) 0%,transparent 50%),radial-gradient(circle at 40% 80%,rgba(212,175,55,.02) 0%,transparent 50%);pointer-events:none;z-index:-1}.container{max-width:1200px;margin:0 auto;padding:0 var(--spacing-md)}.page-transition{opacity:0;transform:translateY(20px);transition:all .4s ease-out}.page-transition.visible{opacity:1;transform:translateY(0)}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:600;line-height:1.3;margin-bottom:var(--spacing-sm)}h1{font-size:clamp(2.5rem,5vw,4rem);font-weight:700;background:linear-gradient(135deg,var(--gold) 0%,var(--gold-hover) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-align:center;margin-bottom:var(--spacing-md)}h2{font-size:clamp(1.8rem,3vw,2.5rem);color:var(--gold)}h3{font-size:clamp(1.3rem,2.5vw,1.8rem);color:var(--text-primary)}p{color:var(--text-secondary);margin-bottom:var(--spacing-sm)}.text-center{text-align:center}.text-muted{color:var(--text-muted)}.mb-0{margin-bottom:0}.mb-sm{margin-bottom:var(--spacing-sm)}.mb-md{margin-bottom:var(--spacing-md)}.mb-lg{margin-bottom:var(--spacing-lg)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.animate-fade-in-up{animation:fadeInUp .6s ease-out forwards}.animate-fade-in{animation:fadeIn .4s ease-out forwards}@media (max-width: 768px){.container{padding:0}:root{--spacing-xl: 2rem;--spacing-2xl: 2.5rem}}*:focus{outline:2px solid var(--gold);outline-offset:2px}::selection{background-color:var(--gold);color:var(--primary-bg)}.chess-viewer{height:100%;display:flex;flex-direction:column;padding:var(--spacing-md) 0}.viewer-content{display:grid;grid-template-columns:1fr 2fr 1fr;gap:var(--spacing-md);padding:0 var(--spacing-md);height:100%;align-items:start;min-height:0}.left-section{display:flex;flex-direction:column;gap:var(--spacing-lg);height:100%;min-width:200px}.left-section .game-info{text-align:left}.left-section .title-row{display:flex;align-items:flex-start;gap:var(--spacing-md)}.left-section .title-content{flex:1}.left-section .game-title{font-size:1.4rem;color:var(--gold);margin-bottom:var(--spacing-xs);line-height:1.2}.left-section .game-subtitle{color:var(--text-muted);font-size:1rem;margin-bottom:0;line-height:1.4}.game-actions{display:flex;flex-direction:row;gap:var(--spacing-sm)}.back-button{--size: 40px;background:var(--secondary-bg);border:1px solid var(--border);color:var(--text-secondary);padding:var(--spacing-sm);border-radius:50%;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;width:var(--size);height:var(--size);box-shadow:0 2px 4px #0003;flex-shrink:0}.back-button svg{stroke:currentColor;transition:stroke .3s ease}.back-button:hover{border-color:var(--gold);color:var(--gold);background:#d4af371a;transform:translate(-3px) translateY(-1px);box-shadow:0 4px 8px #0000004d}.download-button,.lichess-button{--size: 40px;background:var(--secondary-bg);border:1px solid var(--border);color:var(--text-secondary);padding:var(--spacing-sm);border-radius:50%;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;width:var(--size);height:var(--size);box-shadow:0 2px 4px #0003;flex-shrink:0}.download-button svg,.lichess-button svg{stroke:currentColor;transition:stroke .3s ease}.download-button:hover:not(:disabled),.lichess-button:hover:not(:disabled){border-color:var(--gold);color:var(--gold);background:#d4af371a;transform:translate(3px) translateY(-1px);box-shadow:0 4px 8px #0000004d}.download-button:disabled,.lichess-button:disabled{opacity:.5;cursor:not-allowed}.download-button:disabled:hover,.lichess-button:disabled:hover{transform:none}.annotations-section{background:var(--secondary-bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--spacing-md);flex:1;overflow:hidden}.annotations-section .annotations-header{margin-bottom:var(--spacing-sm);border-bottom:1px solid var(--border);padding-bottom:var(--spacing-xs)}.annotations-section .annotations-header h3{color:var(--gold);font-size:1.1rem;margin-bottom:0}.annotations-section .annotations-content{flex:1;overflow-y:auto}.annotations-section .annotations-content .annotation-text{color:var(--text-primary);font-size:1.1rem;line-height:1.6;margin:6px 0;padding:var(--spacing-md);background:var(--primary-bg);border-radius:var(--radius-md);border-left:3px solid var(--gold)}.annotations-section .annotations-content .annotation-link{color:var(--gold);text-decoration:none;transition:all .8s ease;outline:none}.annotations-section .annotations-content .annotation-link:focus{outline:none;box-shadow:none}.annotations-section .annotations-content .annotation-link:visited{color:#daa520}.annotations-section .annotations-content .annotation-link:hover{color:gold!important}.annotations-section .annotations-content .annotation-link.footnote-link sup{font-size:.8em;font-weight:600;padding:2px 4px;background:#d4af3733;border-radius:3px;margin-left:2px}.annotations-section .annotations-content .annotation-link.footnote-link:hover sup{background:#ffd7004d}.annotations-section .annotations-content .annotation-link.footnote-link:focus sup{outline:none;box-shadow:none}.annotations-section .annotations-content .placeholder-text{color:var(--text-muted);font-style:italic;font-size:.9rem;opacity:.7}.board-section{display:flex;justify-content:center;align-items:center;width:fit-content;margin:0 auto}.chess-board-container{background:var(--secondary-bg);border:2px solid var(--gold-muted);border-radius:var(--radius-lg);padding:var(--spacing-sm);box-shadow:var(--shadow-medium);width:fit-content;height:fit-content;display:flex;flex-direction:column;gap:var(--spacing-sm)}.player-name-top,.player-name-bottom{display:flex;justify-content:start;align-items:center;padding:var(--spacing-xxs) var(--spacing-xs)}.player-name{font-size:.9rem;font-weight:600;color:var(--text-primary);padding:2px var(--spacing-xs);min-width:120px;text-align:center;box-shadow:0 2px 4px #0000001a;transition:all .3s ease}.player-name-top .player-name{color:var(--text-secondary);border-color:var(--border)}.player-name-bottom .player-name{color:var(--gold);border-color:var(--gold-muted)}.chessground-board{--board-size: min( calc(100vw - 400px) , calc(100vh - 150px) , 800px );width:var(--board-size);height:var(--board-size);border-radius:var(--radius-md);overflow:hidden;display:block}.moves-section{background:var(--secondary-bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--spacing-md);height:100%;overflow:hidden;display:flex;flex-direction:column;min-width:200px}.move-controls{display:flex;flex-direction:column;height:100%}.move-controls .controls-header{margin-bottom:var(--spacing-sm);border-bottom:1px solid var(--border);padding-bottom:var(--spacing-xs)}.move-controls .controls-header h3{color:var(--gold);font-size:1.1rem;margin-bottom:0;text-align:center}.navigation-controls{display:flex;justify-content:center;gap:var(--spacing-xs);margin-bottom:var(--spacing-sm);padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--border)}.nav-button{background:var(--primary-bg);border:1px solid var(--border);color:var(--text-secondary);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);cursor:pointer;transition:all .2s ease;font-size:1rem;min-width:40px;height:36px;display:flex;align-items:center;justify-content:center}.nav-button svg{stroke:currentColor;transition:stroke .2s ease}.nav-button:hover:not(:disabled){border-color:var(--gold);color:var(--gold);background:#d4af371a;transform:translateY(-1px)}.nav-button:disabled{opacity:.4;cursor:not-allowed}.nav-button:disabled svg{stroke:var(--text-muted)}.moves-list{flex:1;overflow-y:auto;padding-right:var(--spacing-xs);scroll-behavior:smooth;scrollbar-width:none;-ms-overflow-style:none}.moves-list::-webkit-scrollbar{display:none}.move-pair{display:grid;grid-template-columns:28px 1fr 1fr;gap:var(--spacing-xs);margin-bottom:2px;align-items:center;padding:2px 0}.move-number{color:var(--text-muted);font-size:.9rem;font-weight:500;text-align:right;font-variant-numeric:tabular-nums;padding-right:4px}.move-button{background:none;border:1px solid transparent;color:var(--text-secondary);padding:4px 6px;border-radius:var(--radius-sm);cursor:pointer;transition:all .15s ease;font-family:Courier New,monospace;font-size:.85rem;text-align:center;min-height:24px;display:flex;align-items:center;justify-content:center;gap:2px}.move-button:focus{outline:none}.move-button:hover{background:#d4af371a;border-color:var(--gold-muted);color:var(--text-primary)}.move-button.active{background:var(--gold);border-color:var(--gold);color:var(--primary-bg);font-weight:600}.move-button.white{background:#ffffff0d}.move-button.white.active{background:var(--gold);color:var(--primary-bg)}.move-button.black{background:#0003}.move-button.black.active{background:var(--gold);color:var(--primary-bg)}.move-button .move-text{flex:1}.move-button .move-annotation{font-size:.7rem;font-weight:700;opacity:.9}.move-button.annotation-brilliant{background:#00bfff26!important;border-color:#00bfff4d;color:#00bfff}.move-button.annotation-brilliant.active{background:#00bfff!important;color:#fff}.move-button.annotation-brilliant.active .move-annotation{color:#fff}.move-button.annotation-brilliant .move-annotation{color:#00bfff}.move-button.annotation-good{background:#1565c026!important;border-color:#1565c04d;color:#1565c0}.move-button.annotation-good.active{background:#1565c0!important;color:#fff}.move-button.annotation-good.active .move-annotation{color:#fff}.move-button.annotation-good .move-annotation{color:#1565c0}.move-button.annotation-interesting{background:#9c27b026!important;border-color:#9c27b04d;color:#9c27b0}.move-button.annotation-interesting.active{background:#9c27b0!important;color:#fff}.move-button.annotation-interesting.active .move-annotation{color:#fff}.move-button.annotation-interesting .move-annotation{color:#9c27b0}.move-button.annotation-dubious{background:#ffa72626!important;border-color:#ffa7264d;color:#ffa726}.move-button.annotation-dubious.active{background:#ffa726!important;color:#fff}.move-button.annotation-dubious.active .move-annotation{color:#fff}.move-button.annotation-dubious .move-annotation{color:#ffa726}.move-button.annotation-mistake{background:#ff980026!important;border-color:#ff98004d;color:#ff9800}.move-button.annotation-mistake.active{background:#ff9800!important;color:#fff}.move-button.annotation-mistake.active .move-annotation{color:#fff}.move-button.annotation-mistake .move-annotation{color:#ff9800}.move-button.annotation-blunder{background:#f4433633!important;border-color:#f4433666;color:#f44336}.move-button.annotation-blunder.active{background:#f44336!important;color:#fff}.move-button.annotation-blunder.active .move-annotation{color:#fff}.move-button.annotation-blunder .move-annotation{color:#f44336}.games-list{padding:var(--spacing-xl) 0 var(--spacing-2xl) 0}.list-view{scrollbar-width:thin;scrollbar-color:rgba(212,175,55,.3) transparent;transition:scrollbar-color .3s ease .4s}.list-view::-webkit-scrollbar{width:6px;&-track{background:transparent;border-radius:3px;transition:background .3s ease .6s}&-thumb{background:#d4af374d;border-radius:3px;transition:background .3s ease .6s;&:hover{background:#d4af3780}&:active{background:#d4af37b3}}}.view-container.game .list-view{scrollbar-color:transparent transparent;transition:scrollbar-color .3s ease}.view-container.game .list-view::-webkit-scrollbar-thumb{background:transparent;transition:background .3s ease}.view-container.game .list-view::-webkit-scrollbar-track{background:transparent;transition:background .3s ease}.section-title{margin-bottom:var(--spacing-xl);text-align:center;position:relative}.section-title:after{content:"";position:absolute;bottom:-12px;left:50%;transform:translate(-50%);width:80px;height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent)}.featured-section{margin-bottom:var(--spacing-2xl)}.other-games-section{margin-top:var(--spacing-2xl)}.games-grid{display:grid;gap:var(--spacing-lg);margin-bottom:var(--spacing-xl);grid-template-columns:repeat(auto-fit,minmax(350px,1fr))}.games-grid.featured-grid{grid-template-columns:repeat(auto-fit,minmax(400px,1fr))}.empty-state{display:flex;justify-content:center;align-items:center;min-height:400px}.empty-state .empty-content{text-align:center;max-width:400px}.empty-state .empty-content .empty-icon{font-size:4rem;color:var(--gold);margin-bottom:var(--spacing-md);opacity:.7}.empty-state .empty-content h3{color:var(--text-primary);margin-bottom:var(--spacing-sm)}.empty-state .empty-content p{color:var(--text-muted);font-size:1.1rem}.games{list-style:none;max-width:700px;margin:0 auto;padding:0}.game-item{margin-bottom:var(--spacing-sm)}.game-link{display:block;width:100%;background:none;border:none;padding:var(--spacing-md) var(--spacing-lg);text-align:left;cursor:pointer;border-radius:var(--radius-md);transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;opacity:0;transform:translateY(20px);animation:slideInUp .6s ease-out forwards}.game-link:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(212,175,55,.1),transparent);transition:left .5s ease}.game-link:hover{background:#d4af3714;transform:translate(8px);border-left:3px solid var(--gold)}.game-link:hover:before{left:100%}.game-link:hover .game-title{color:var(--gold-hover)}.game-link:hover .game-subtitle{color:var(--text-secondary)}.game-link:hover .game-score{color:var(--gold);background:#d4af3726;transform:scale(1.05)}.game-link:hover .preload-indicator{opacity:1;transform:scale(1.1)}.game-link:active{transform:translate(4px) scale(.98)}.game-link.transitioning,.game-link:disabled{pointer-events:none;opacity:.6;transform:none!important;cursor:not-allowed}.game-link.transitioning:hover,.game-link:disabled:hover{background:none;transform:none!important;border-left:none}.game-link.transitioning:before,.game-link:disabled:before{display:none}.game-content{display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-md)}.game-meta{display:flex;align-items:center;gap:var(--spacing-sm);flex-shrink:0}.game-info{min-width:0}.game-title{display:block;font-family:var(--font-heading);font-size:1.3rem;font-weight:600;color:var(--gold);margin-bottom:var(--spacing-xs);transition:color .2s ease}.game-subtitle{display:block;font-size:.9rem;color:var(--text-muted);font-weight:400;transition:color .2s ease}.game-score{font-size:1.1rem;font-weight:600;color:var(--gold-muted);background:#d4af371a;padding:.25rem .75rem;border-radius:var(--radius-sm);transition:all .2s ease;flex-shrink:0;font-variant-numeric:tabular-nums}.preload-indicator{font-size:1rem;opacity:.8;transition:all .2s ease;-webkit-user-select:none;user-select:none}.preload-indicator.loading{animation:pulse 1.5s ease-in-out infinite}.header{padding:var(--spacing-2xl) 0 var(--spacing-lg) 0;padding-top:calc(var(--spacing-2xl) + var(--spacing-md));text-align:center;transition:all .4s ease}.header.compact{padding:var(--spacing-lg) 0 var(--spacing-sm) 0;transform:translateY(-10px);opacity:.7}.header.compact .site-title{font-size:clamp(1.2rem,3vw,1.8rem);margin-bottom:0}.header.compact .site-subtitle{opacity:0;transform:translateY(-10px);pointer-events:none;max-height:0}.header .container{position:relative}.mobile-back-button{display:none}.site-title{margin-bottom:0;font-size:clamp(2.5rem,5vw,4rem);font-weight:700;background:linear-gradient(135deg,var(--gold) 0%,var(--gold-hover) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;opacity:0;animation:fadeInUp .8s ease-out .2s forwards;transition:all .4s ease;-webkit-user-select:none;user-select:none}.site-subtitle{font-size:1.1rem;color:var(--text-muted);font-weight:300;letter-spacing:.5px;margin-bottom:0;opacity:0;animation:fadeInUp .8s ease-out .4s forwards;transition:opacity .4s ease,transform .4s ease,max-height .4s ease;transform:translateY(0);max-height:2em;overflow:hidden}.loading-message,.error-message{text-align:center;color:var(--gold);font-size:1.1rem;padding:2rem;opacity:.8;animation:fadeIn .5s ease-out}.error-message{color:#ff6b6b}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:.8;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:.8}50%{opacity:.4}}@media (max-width: 1440px) and (min-width: 768px){.viewer-content{display:grid;grid-template-columns:1.2fr 1fr;grid-template-rows:auto 1fr;grid-template-areas:"board moves" "game-info annotations";gap:var(--spacing-md);height:calc(100vh - 120px);overflow:hidden;padding:0 var(--spacing-md)}.board-section{grid-area:board;justify-self:center}.moves-section{grid-area:moves;overflow:hidden;display:flex;flex-direction:column;height:calc(min(calc(100vw - 280px),65vh,600px) + 90px)}.left-section{display:contents}.left-section>.game-info,.left-section>.title-row{grid-area:game-info;display:flex;flex-direction:column;gap:var(--spacing-sm);min-height:0}.annotations-section{grid-area:annotations;height:100%;overflow:hidden}.annotations-section .annotations-content{flex:1;overflow-y:auto;scrollbar-width:thin}.chessground-board{--board-size: min( calc(100vw - 280px) , 65vh , 600px )}.chess-board-container{width:fit-content;height:fit-content}.moves-list{flex:1;overflow-y:auto;font-size:.85rem;min-height:0}.move-pair{grid-template-columns:24px 1fr 1fr;gap:4px;margin-bottom:2px}.move-button{font-size:.8rem;padding:3px 5px;min-height:22px}.move-number{font-size:.8rem}.navigation-controls{gap:4px;margin-bottom:var(--spacing-sm);padding-bottom:var(--spacing-sm);flex-shrink:0}.nav-button{min-width:36px;height:30px}.nav-button svg{width:14px;height:14px}.left-section .title-row{align-items:flex-start;gap:var(--spacing-sm)}.left-section .game-info{flex:1;min-width:250px}.left-section .game-title{font-size:1.3rem;margin-bottom:var(--spacing-sm);line-height:1.3}.left-section .game-subtitle{font-size:1rem;line-height:1.4}.back-button,.download-button{--size: 40px;flex-shrink:0}.back-button svg,.download-button svg{width:20px;height:20px}}@media (max-width: 768px){.chess-viewer{padding:0;height:100%;overflow:hidden;display:flex;flex-direction:column}.viewer-content{padding:0;gap:0;height:100%;grid-template-columns:1fr;grid-template-rows:auto minmax(0,1fr);overflow:hidden;flex:1;justify-items:center;align-items:start}.board-section{order:0;margin:0;display:flex;align-items:center;justify-content:center;background:var(--primary-bg);padding:var(--spacing-sm) 0 0 0;max-height:70vh;overflow:hidden;width:100%}.chess-board-container{background:transparent;border:none;padding:0;box-shadow:none;width:100%;display:flex;justify-content:center;gap:0}.chessground-board{--board-size: min(100vw, 70vh) !important;border-radius:0!important}.moves-section{order:1;width:100%;padding:var(--spacing-sm);margin:0;border-radius:0;border-left:none;border-right:none;border-bottom:none;box-sizing:border-box;display:flex;flex-direction:column;min-height:0;overflow:hidden}.moves-section .moves-list{flex:1;overflow-y:auto;padding-bottom:var(--spacing-md);min-height:0}.left-section{display:none}.player-name{padding-left:8px!important;font-size:1rem;min-width:100px;padding:4px var(--spacing-xs)}.games-grid{grid-template-columns:1fr;gap:var(--spacing-md)}.games-grid.featured-grid{grid-template-columns:1fr}.games-list{padding:var(--spacing-lg) 0 var(--spacing-xl) 0}.featured-section{margin-bottom:var(--spacing-xl)}.other-games-section{margin-top:var(--spacing-xl)}.games{padding-left:10px;padding-right:10px;max-width:100%}.game-link{padding:var(--spacing-sm) var(--spacing-md)}.game-link:hover{transform:translate(4px)}.game-content{gap:var(--spacing-sm)}.game-title{font-size:1.2rem}.game-subtitle{font-size:.85rem}.game-score{font-size:1rem;padding:.2rem .6rem}.header{padding:var(--spacing-xl) 0 var(--spacing-md) 0;padding-top:calc(var(--spacing-xl) + var(--spacing-sm))}.header.compact{padding:var(--spacing-md) 0 var(--spacing-xs) 0}.mobile-back-button{display:flex;position:absolute;left:var(--spacing-sm);top:50%;transform:translateY(-50%);background:transparent;border:none;color:var(--text-secondary);padding:var(--spacing-xs);cursor:pointer;transition:all .3s ease;align-items:center;justify-content:center;width:28px;height:28px;z-index:100}.mobile-back-button svg{stroke:currentColor;transition:stroke .3s ease}.mobile-back-button:hover{color:var(--gold);transform:translateY(-50%) translate(-2px)}.mobile-back-button:hover svg{stroke:var(--gold)}.site-subtitle{font-size:1rem;padding:0 var(--spacing-sm)}.navigation-controls{gap:var(--spacing-xs)}.nav-button{min-width:36px;height:32px;font-size:.9rem}.nav-button svg{width:14px;height:14px}.move-pair{grid-template-columns:24px 1fr 1fr}.move-button{font-size:.8rem;padding:3px 4px;min-height:22px}}@media (max-width: 480px){.moves-section{padding:8px}.moves-section .moves-list{height:100%;padding-bottom:12px}.board-section{padding-top:0}.section-title{margin-bottom:var(--spacing-lg)}.game-link{padding:var(--spacing-sm)}.game-content{flex-direction:column;align-items:flex-start;gap:var(--spacing-xs)}.game-info{width:100%}.game-title{font-size:1.1rem}.game-score{align-self:flex-end;font-size:.9rem}}
