.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-wrap coords.squares{bottom:0;left:0;text-transform:uppercase;text-align:right;flex-flow:column-reverse;height:100%;width:12.5%}.cg-wrap coords.squares.black{flex-flow:column}.cg-wrap coords.squares.left{text-align:left}.cg-wrap coords.squares coord{padding:6% 4%}.cg-wrap coords.squares.rank2{transform:translate(100%)}.cg-wrap coords.squares.rank3{transform:translate(200%)}.cg-wrap coords.squares.rank4{transform:translate(300%)}.cg-wrap coords.squares.rank5{transform:translate(400%)}.cg-wrap coords.squares.rank6{transform:translate(500%)}.cg-wrap coords.squares.rank7{transform:translate(600%)}.cg-wrap coords.squares.rank8{transform:translate(700%)}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:#9bc70069}cg-board square.selected{background-color:#14551e80}cg-board square.check{background:radial-gradient(ellipse at center,red,#e70000 25%,#a9000000 89%,#9e000000)}cg-board square.current-premove{background-color:#141e5580}.orientation-white .ranks :nth-child(odd),.orientation-white .files :nth-child(2n),.orientation-black .ranks :nth-child(2n),.orientation-black .files :nth-child(odd),coords.squares:nth-of-type(odd) :nth-child(2n),coords.squares:nth-of-type(2n) :nth-child(odd){color:#484848cc}.orientation-white .ranks :nth-child(2n),.orientation-white .files :nth-child(odd),.orientation-black .ranks :nth-child(odd),.orientation-black .files :nth-child(2n),coords.squares:nth-of-type(odd) :nth-child(odd),coords.squares:nth-of-type(2n) :nth-child(2n){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{--accent: var(--color-accent);--border: var(--color-border);--text-primary: var(--color-text);--text-secondary: var(--color-text-muted)}cg-board square.check{background:radial-gradient(ellipse at center,#ff0000b8,#c8000080 30%,#8c000000 80%)!important}.cg-wrap{width:100%;height:100%;touch-action:none;overflow:hidden}coords coord{font-size:clamp(10px,1.75cqw,14px);font-weight:400;text-transform:lowercase;line-height:1}.cg-wrap coords.ranks{left:calc(var(--board-coord-inset) - 2px)}.cg-wrap coords.ranks coord{transform:translateY(calc(18px + var(--board-coord-inset)))}.cg-wrap coords.files{left:0;text-align:left}.cg-wrap coords.files coord{box-sizing:border-box;padding-left:var(--board-coord-inset);transform:translateY(calc(var(--board-file-offset) - 2px))}.orientation-white .ranks coord:nth-child(odd),.orientation-white .files coord:nth-child(odd){color:#fffffff2!important}.orientation-white .ranks coord:nth-child(2n),.orientation-white .files coord:nth-child(2n){color:#281c0ee6!important}.orientation-black .ranks coord:nth-child(odd),.orientation-black .files coord:nth-child(odd){color:#281c0ee6!important}.orientation-black .ranks coord:nth-child(2n),.orientation-black .files coord:nth-child(2n){color:#fffffff2!important}cg-board{background-image:url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiIHN0YW5kYWxvbmU9Im5vIj8+CjxzdmcgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB4bWxuczp4PSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hsaW5rIgogICAgIHZpZXdCb3g9IjAgMCA4IDgiIHNoYXBlLXJlbmRlcmluZz0iY3Jpc3BFZGdlcyI+CjxnIGlkPSJhIj4KICA8ZyBpZD0iYiI+CiAgICA8ZyBpZD0iYyI+CiAgICAgIDxnIGlkPSJkIj4KICAgICAgICA8cmVjdCB3aWR0aD0iMSIgaGVpZ2h0PSIxIiBpZD0iZSIgb3BhY2l0eT0iMCIvPgogICAgICAgIDx1c2UgeD0iMSIgeT0iMSIgaHJlZj0iI2UiIHg6aHJlZj0iI2UiLz4KICAgICAgICA8cmVjdCB5PSIxIiB3aWR0aD0iMSIgaGVpZ2h0PSIxIiBpZD0iZiIgb3BhY2l0eT0iMC4zOCIvPgogICAgICAgIDx1c2UgeD0iMSIgeT0iLTEiIGhyZWY9IiNmIiB4OmhyZWY9IiNmIi8+CiAgICAgIDwvZz4KICAgICAgPHVzZSB4PSIyIiBocmVmPSIjZCIgeDpocmVmPSIjZCIvPgogICAgPC9nPgogICAgPHVzZSB4PSI0IiBocmVmPSIjYyIgeDpocmVmPSIjYyIvPgogIDwvZz4KICA8dXNlIHk9IjIiIGhyZWY9IiNiIiB4OmhyZWY9IiNiIi8+CjwvZz4KPHVzZSB5PSI0IiBocmVmPSIjYSIgeDpocmVmPSIjYSIvPgo8L3N2Zz4=)}.chess-board-container{--board-coord-inset: .75cqw;--board-file-offset: clamp(2px, .55cqw, 4px);width:100%;aspect-ratio:1;position:relative;flex-shrink:0;container-type:inline-size}.app-main{flex:1;min-height:0;display:flex;gap:1rem;padding:.75rem 1.5rem;align-items:stretch;overflow-y:hidden;overflow-x:hidden}.board-col{flex:0 0 auto;display:flex;flex-direction:column;min-width:0;align-self:flex-start}.player-bar{height:32px;display:flex;align-items:center;gap:.5rem;padding:0 4px;flex-shrink:0}.to-move-dot{width:10px;height:10px;border-radius:50%;background:var(--color-border);flex-shrink:0;transition:background .2s}.to-move-dot.active{background:#4ade80}.player-name{font-weight:500;font-size:1.1rem;color:var(--color-text)}.player-elo{color:var(--color-text-muted);font-size:.8rem}.player-info-box{height:44px;background:#4d4d4d;box-sizing:border-box;display:flex;align-items:center;gap:.6rem;padding:.4rem .6rem;flex-shrink:0;overflow:hidden;color:#fff}.player-avatar{width:36px;height:36px;flex-shrink:0;border-radius:4px;overflow:hidden}.avatar-image{width:100%;height:100%;object-fit:cover}.avatar-fallback{width:100%;height:100%;background:#4a9eff;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:1rem}.avatar-fallback--neutral{background:#555;color:#aaa;font-size:1.3rem}.player-info-lines{flex:1;min-width:0;display:flex;flex-direction:column;justify-content:center;gap:1px;padding-bottom:4px}.player-line-1{display:flex;align-items:center;gap:.4rem}.player-name{font-weight:700;font-size:.92rem;color:#fff;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.player-rating{color:#aaa;font-size:.85rem;flex-shrink:0}.player-flag{font-size:1rem;flex-shrink:0}.player-line-2{display:flex;align-items:center;gap:.3rem}.captured-pieces{display:flex;gap:0;flex-wrap:nowrap}.captured-piece-img{width:16px;height:16px;flex-shrink:0;display:inline-block;vertical-align:middle}.material-advantage{font-size:.78rem;font-weight:600;color:#aaa;margin-left:2px}.clock-box{display:flex;align-items:center;justify-content:center;min-width:64px;height:38px;padding:0 10px;border-radius:6px;background:#333;border:1px solid #555;flex-shrink:0;margin-left:auto;margin-right:-.3rem}.clock-value{font-family:var(--font-mono, "Courier New", monospace);font-size:1.35rem;font-weight:700;color:#aaa;font-variant-numeric:tabular-nums}.clock-box--active{background:#fff}.clock-box--active .clock-value{color:#1a1a1a}.board-controls{display:flex;align-items:center;flex-wrap:wrap;justify-content:space-between;gap:.5rem .75rem;margin-top:.35rem;margin-left:24px;flex-shrink:0;width:calc(100% - 24px);max-width:100%;row-gap:.5rem}.board-controls__nav,.board-controls__actions{display:flex;align-items:center;flex-wrap:wrap;gap:.5rem}.board-controls__actions{flex:1 1 auto}.board-control-btn{min-height:32px;padding:.42rem .82rem;border-radius:8px;font-size:.78rem;font-weight:600;letter-spacing:.01em}.board-control-btn--active,.board-btn--active{background:#4a9eff26;border-color:var(--color-accent, #4a9eff)!important;color:var(--color-accent, #4a9eff);box-shadow:inset 0 0 0 1px #4a9eff2e}.board-control-btn--danger,.board-btn--danger{background:#dc3c3c26;border-color:#dc3c3c80!important;color:#f87171}.board-control-btn--danger:hover,.board-btn--danger:hover{background:#dc3c3c47}.board-control-status{min-height:32px;display:inline-flex;align-items:center;padding:.42rem .75rem;border:1px solid var(--color-border);border-radius:8px;background:#ffffff0a;color:var(--color-text-muted);font-size:.78rem;font-weight:500;white-space:nowrap}.nav-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text);font-size:1.1rem;cursor:pointer;transition:border-color .15s,color .15s}.nav-btn:hover:not(:disabled){border-color:var(--color-accent);color:var(--color-accent)}.nav-btn:disabled{opacity:.35;cursor:not-allowed}.move-counter{font-size:.8rem;color:var(--color-text-muted);font-family:var(--font-mono);min-width:56px;text-align:center}.side-col{flex:1 1 290px;width:min(330px,100%);min-width:270px;max-width:330px;display:flex;flex-direction:column;min-height:0}.panel-tabs{height:32px;display:flex;align-items:center;gap:.25rem;flex-shrink:0;border-bottom:1px solid var(--color-border);padding:0 4px}.panel-tab{padding:.2rem .75rem;background:none;border:none;border-radius:var(--radius);color:var(--color-text-muted);font-size:.8rem;font-weight:500;cursor:pointer;transition:color .15s}.panel-tab:hover:not(:disabled){color:var(--color-text)}.panel-tab.active{color:var(--color-accent);font-weight:600}.panel-tab:disabled{opacity:.3;cursor:not-allowed}.side-panel-wrapper{flex:1;min-height:0;display:flex;flex-direction:column;position:relative}.panel-analyzing-label{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:.75rem;color:var(--color-accent);font-weight:500;pointer-events:none;z-index:1;white-space:nowrap}.panel-content--analyzing{opacity:.35;pointer-events:none}.panel-content{flex:1;min-height:0;overflow-y:auto;display:flex;flex-direction:column;gap:.5rem;padding-top:.5rem}.move-list{flex:1;min-height:0;overflow-y:auto;max-height:none;font-family:var(--font-mono);font-size:.875rem;padding:.5rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text)}.move-full-row{display:block}.move-pair-row{display:flex;align-items:center;gap:2px;padding:1px 0;min-height:24px}.move-number{color:var(--color-text-muted);min-width:28px;text-align:right;flex-shrink:0;-webkit-user-select:none;user-select:none;font-size:.8rem;margin-right:2px}.move-cell{display:inline-flex;align-items:center;gap:2px;flex-shrink:0}.move-san{cursor:pointer;padding:2px 6px;border-radius:3px;min-width:66px;transition:background .1s,color .1s;display:inline-block;white-space:nowrap}.move-san:hover{background:var(--color-surface-2);color:var(--color-text)}.move-eval-delta{font-size:.62rem;font-family:var(--font-mono, monospace);font-variant-numeric:tabular-nums;color:var(--color-text-muted);opacity:.55;flex-shrink:0;width:6ch;padding:0 5px;text-align:right;-webkit-user-select:none;user-select:none;white-space:nowrap}.move-active{background:var(--color-accent);color:#fff;font-weight:600}.move-active:hover{background:var(--color-accent-hover)}.move-in-path{color:var(--color-accent);opacity:.7}.variation-blocks{display:block;margin-top:1px;margin-bottom:2px}.variation-block{display:block;margin:2px 0 2px 8px;padding:2px 4px 2px 8px;border-left:2px solid var(--color-border);font-size:.82rem;color:var(--color-text-muted)}.variation-block .move-san{color:var(--color-text-muted);min-width:46px}.variation-block .move-san:hover{color:var(--color-text)}.variation-block .move-active{color:#fff}.variation-depth-2{margin-left:14px;font-size:.79rem}.variation-depth-3{margin-left:20px;font-size:.76rem}.move-result{text-align:center;margin-top:.5rem;padding:.25rem;color:var(--color-text-muted);font-size:.8rem;border-top:1px solid var(--color-border)}.import-panel{display:flex;flex-direction:column;gap:.75rem}.import-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted)}.import-textarea{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text);padding:.5rem;font-size:.75rem;font-family:var(--font-mono);width:100%;resize:vertical;outline:none;line-height:1.5}.import-textarea:focus{border-color:var(--color-accent)}.import-error{color:#f87171;font-size:.8rem}.fen-row{display:flex;gap:.5rem}.fen-input{flex:1;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text);padding:.4rem .6rem;font-size:.75rem;font-family:var(--font-mono);outline:none;min-width:0}.fen-input:focus{border-color:var(--color-accent)}.btn{padding:.4rem .9rem;border:none;border-radius:var(--radius);font-size:.8rem;font-weight:500;cursor:pointer;transition:background .15s,opacity .15s;white-space:nowrap}.btn:disabled{cursor:not-allowed}.btn:active:not(:disabled){opacity:.85}.btn-primary{background:var(--color-accent);color:#fff}.btn-primary:hover:not(:disabled){background:var(--color-accent-hover)}.btn-secondary{background:var(--color-surface-2);color:var(--color-text);border:1px solid var(--color-border)}.btn-secondary:hover:not(:disabled){border-color:var(--color-accent);color:var(--color-accent)}.nav-logo{display:flex;align-items:center;gap:.3rem;padding:.4rem .6rem;border-bottom:1px solid var(--color-border);cursor:pointer;justify-content:space-between;transition:background .15s}.nav-logo:hover{background:#ffffff0a}.nav-logo__img{width:32px;height:32px;flex-shrink:0}.nav-logo__name{font-size:1.1rem;font-weight:700;letter-spacing:-.02em;color:var(--color-text);flex:1}.nav-logo-toggle{background:none;border:none;color:var(--color-text-muted);cursor:pointer;padding:.2rem .3rem;flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:color .15s;border-radius:4px}.nav-logo-toggle:hover{color:var(--color-text);background:#ffffff14}.nav-sidebar{width:var(--layout-nav-width);flex-shrink:0;transition:width .2s ease;display:flex;flex-direction:column;border-right:1px solid var(--color-border);padding:.25rem 0;background:var(--color-surface)}.nav-item{display:flex;align-items:center;gap:.75rem;padding:.6rem 1rem;border-left:3px solid transparent;color:var(--color-text-muted);font-size:.875rem;cursor:pointer;transition:color .15s,border-color .15s,background .15s;-webkit-user-select:none;user-select:none}.nav-item:hover{color:var(--color-text)}.nav-item.active{color:var(--color-accent);border-left-color:var(--color-accent);background:#4a9eff0f}.nav-icon{font-size:1rem;flex-shrink:0;width:1.2rem;text-align:center;display:inline-flex;align-items:center;justify-content:center}.nav-soon{font-size:.65rem;background:var(--color-surface-2);border-radius:3px;padding:0 4px;color:var(--color-text-muted);margin-left:auto}.board-with-eval{display:flex;gap:8px;align-items:stretch;max-width:100%;width:fit-content}.board-and-players{display:flex;flex-direction:column;flex-shrink:0;min-width:0;width:min(880px,calc(100dvh - 164px),calc(100vw - var(--board-vw-offset)));border:1px solid #505050;background:#4d4d4d}.player-info-box{width:100%}.eval-bar-container{width:16px;flex-shrink:0;position:relative;border-radius:var(--radius);overflow:visible;border:1px solid var(--color-border)}.eval-bar-inner{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden;border-radius:var(--radius)}.eval-bar-segment{position:absolute;left:0;right:0;transition:height .2s ease-out,background 0s}.eval-bar-top{top:0}.eval-bar-bot{bottom:0}.eval-bar-midline{position:absolute;top:50%;left:0;width:100%;height:1px;background:#8080808c;pointer-events:none;z-index:5}.eval-bar-label{position:absolute;left:50%;transform:translate(-50%) translateY(-50%);font-size:.6rem;font-weight:700;font-family:var(--font-mono);line-height:1;background:#0f1220d9;color:#e2e8f0;padding:2px 4px;border-radius:3px;pointer-events:none;white-space:nowrap;z-index:10;border:1px solid var(--color-border)}.eval-bar-container:has(.eval-bar-analyzing){border-color:var(--color-accent);animation:eval-pulse 1.5s ease-in-out infinite}.eval-bar-analyzing{display:none}@keyframes eval-pulse{0%,to{border-color:var(--color-border)}50%{border-color:var(--color-accent)}}.stub-page{display:flex;align-items:center;justify-content:center;flex:1;color:var(--color-text-muted);font-size:1rem}@media (max-width: 1180px){.app-main{flex-direction:column;overflow-y:auto;align-items:stretch;padding:1rem}.board-col{width:100%;max-width:100%}.board-with-eval{width:100%;gap:6px}.board-and-players{flex:1 1 auto;width:100%}.chess-board-container{width:100%!important;max-width:100%;height:auto!important;aspect-ratio:1 / 1}.side-col{flex:1 1 auto;width:100%;max-width:100%;min-width:0;min-height:360px}.board-controls{flex-wrap:wrap;padding-left:0;margin-left:22px;width:calc(100% - 22px)}.panel-tabs{height:auto;flex-wrap:wrap}.panel-tab{flex:1 1 96px;text-align:center}}@media (max-width: 860px){.app-main{padding:.75rem;gap:.75rem}.eval-bar-container{width:12px}.board-controls{margin-left:18px;width:calc(100% - 18px)}.import-tabs,.fen-row,.account-link-row,.game-list__load-actions,.game-result-actions{flex-wrap:wrap}.fen-row>.btn,.account-link-row>.btn,.game-list__load-actions>*,.game-result-actions>*{width:100%}.side-col{min-height:320px}}@media (max-width: 480px){.board-col{max-width:calc(100vw - .75rem)}.board-with-eval{gap:4px}.eval-bar-container{width:10px}.board-controls{justify-content:flex-start;gap:.35rem;margin-left:14px;width:calc(100% - 14px)}.board-controls__nav,.board-controls__actions{width:100%}.board-and-players{width:calc(100% - 6px);margin:0 auto}.board-controls .btn,.board-control-status{padding:.35rem .65rem;font-size:.76rem}.nav-btn{width:30px;height:30px}.move-counter{min-width:0;font-size:.75rem}.panel-tabs{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.2rem}.panel-tab,.import-tab{font-size:.74rem;min-width:0}.import-tabs{display:grid;grid-template-columns:repeat(3,minmax(0,1fr))}.player-info-box{height:36px;padding:2px 6px;gap:.4rem}.player-avatar{width:30px;height:30px}.player-name{font-size:.8rem}.player-rating{font-size:.75rem}.player-flag{font-size:.85rem}.captured-piece-img{width:14px;height:14px}.clock-box{min-width:52px;height:30px;padding:0 6px}.clock-value{font-size:1.1rem}}.side-panel-content{flex:1;min-height:0;display:flex;flex-direction:column;gap:.5rem;padding:.5rem 0;overflow:hidden}.panel-empty{display:flex;align-items:center;justify-content:center;flex:1;color:var(--color-text-muted);font-size:.85rem}.analyzing-bar{display:flex;align-items:center;gap:.4rem;padding:.3rem .5rem;background:#4a9eff0f;border:1px solid rgba(74,158,255,.2);border-radius:var(--radius);flex-shrink:0;position:relative;overflow:hidden}.analyzing-bar__fill{position:absolute;left:0;top:0;bottom:0;background:#4a9eff47;transition:width .4s ease;pointer-events:none}.analyzing-dot{width:6px;height:6px;border-radius:50%;background:var(--color-accent);flex-shrink:0;animation:analyzing-pulse 1.2s ease-in-out infinite}@keyframes analyzing-pulse{0%,to{opacity:1}50%{opacity:.3}}.analyzing-text{font-size:.75rem;color:var(--color-accent);font-family:var(--font-mono)}.eval-display{display:flex;align-items:baseline;gap:.5rem;padding:.35rem .5rem;flex-shrink:0}.eval-display-value{font-family:var(--font-mono);font-size:1rem;font-weight:600;color:var(--color-text)}.eval-display-depth{font-size:.7rem;color:var(--color-text-muted);font-family:var(--font-mono)}.eval-graph-wrap{flex-shrink:0;display:flex;flex-direction:column;gap:1px;position:relative}.eval-graph-container{flex-shrink:0;flex-grow:0;height:120px;border-radius:var(--radius);overflow:hidden;border:1px solid var(--color-border);background:#0f1117;cursor:crosshair}.eval-graph-svg{display:block;width:100%;height:120px;min-height:120px;max-height:120px;flex-shrink:0}.eval-graph-empty{height:120px;display:flex;align-items:center;justify-content:center;cursor:default}.eval-graph-waiting{font-size:.75rem;color:var(--color-text-muted)}.move-grade{font-size:.7rem;font-weight:900;font-family:system-ui,-apple-system,sans-serif;border-radius:50%;width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center;padding:0;line-height:1;flex-shrink:0;-webkit-user-select:none;user-select:none;color:#fff;letter-spacing:-.03em}.grade-brilliant,.grade-blunder,.grade-inaccuracy{font-size:.55rem}.grade-placeholder{display:inline-block;width:18px;height:18px;flex-shrink:0}.grade-brilliant{background:#22d3ee}.grade-great{background:#16a34a}.grade-best{background:#22c55e}.grade-excellent{background:#4ade80}.grade-good{background:#60a5fa}.grade-forced{background:#6b7280}.grade-inaccuracy{background:#facc15;color:#1a1a1a}.grade-mistake{background:#fb923c}.grade-blunder{background:#ef4444}.grade-miss{background:#a78bfa}.grade-pending{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;flex-shrink:0;border-radius:50%;background:#374151;position:relative}.grade-pending:after{content:"";position:absolute;top:3px;right:3px;bottom:3px;left:3px;border-radius:50%;border:1.5px solid transparent;border-top-color:#9ca3af;animation:grade-spin .7s linear infinite}@keyframes grade-spin{to{transform:rotate(360deg)}}.board-grade-badge{position:absolute;z-index:10;width:16%;max-width:36px;aspect-ratio:1;border-radius:50%;transform:translate(-75%,-25%);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:900;font-family:system-ui,-apple-system,sans-serif;font-size:clamp(.65rem,2.6vw,1rem);line-height:1;pointer-events:none;letter-spacing:-.03em;box-shadow:inset 0 0 0 2px #ffffff59,0 2px 8px #0000008c}.board-grade-badge[data-grade=brilliant],.board-grade-badge[data-grade=blunder],.board-grade-badge[data-grade=inaccuracy]{font-size:clamp(.5rem,2vw,.75rem)}.board-grade-badge-pending{position:absolute;z-index:10;width:16%;max-width:36px;aspect-ratio:1;border-radius:50%;transform:translate(-75%,-25%);background:#1e1e1ebf;box-shadow:inset 0 0 0 2px #ffffff26,0 2px 8px #0000008c;pointer-events:none}.board-grade-badge-pending:after{content:"";position:absolute;top:20%;right:20%;bottom:20%;left:20%;border-radius:50%;border:2px solid transparent;border-top-color:#ffffffb3;animation:grade-spin .7s linear infinite}.board-result-badge{position:absolute;z-index:11;width:16%;max-width:36px;aspect-ratio:1;border-radius:50%;transform:translate(-75%,-25%);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:900;font-family:system-ui,-apple-system,sans-serif;font-size:clamp(.65rem,2.6vw,1rem);line-height:1;pointer-events:none;box-shadow:inset 0 0 0 2px #ffffff59,0 2px 8px #0000008c}.board-result-badge--checkmate{background:#111}.board-result-badge--draw{background:#6b7280;font-size:clamp(.5rem,1.8vw,.75rem)}.move-pair{display:flex;align-items:center;gap:.2rem;padding:1px 0}.move-placeholder{flex:1}.parse-error{color:#f87171;font-size:.8rem;text-align:center;padding:0 .5rem}.analyzing-bar--error{background:#f8717114;border-color:#f8717140}.analyzing-bar--error .analyzing-text{color:#f87171}.best-lines{display:flex;flex-direction:column;gap:2px;height:66px;flex-shrink:0;overflow:hidden}.best-line-row{height:32px;box-sizing:border-box;display:flex;align-items:center;gap:.5rem;padding:.35rem .5rem;border-radius:5px;background:#ffffff0a;border:1px solid rgba(255,255,255,.06);cursor:pointer;width:100%;text-align:left;transition:background .12s,opacity .15s ease;font-size:.82rem;color:var(--color-text)}.best-line-row:hover{background:#ffffff17;border-color:#ffffff26}.best-line-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}.best-line-move{font-weight:600;font-family:var(--font-mono, monospace);min-width:2.8rem;color:var(--color-text)}.best-line-eval{margin-left:auto;font-variant-numeric:tabular-nums;color:var(--color-text-muted);font-size:.78rem}.best-line-skeleton{height:32px;background:linear-gradient(90deg,#ffffff0a 25%,#ffffff14,#ffffff0a 75%);background-size:200% 100%;animation:skeleton-shimmer 1.4s infinite;cursor:default}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.best-line-spacer{visibility:hidden;pointer-events:none}.best-lines-section{display:flex;flex-direction:column;gap:4px;margin-bottom:.25rem}.lines-toggle-btn{align-self:flex-start;padding:.25rem .65rem;background:#ffffff0d;border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text-muted);font-size:.75rem;font-weight:500;cursor:pointer;transition:background .12s,border-color .12s,color .12s}.lines-toggle-btn:hover{background:#ffffff17;border-color:var(--color-accent);color:var(--color-text)}.lines-toggle-btn.active{background:#4ade801a;border-color:#4ade8059;color:#4ade80}.eval-graph-tooltip{position:absolute;bottom:calc(100% + 4px);transform:translate(-50%);pointer-events:none;display:flex;flex-direction:column;align-items:center;z-index:10;background:#0c0e14f2;border:1px solid var(--color-border);border-radius:5px;padding:4px 8px;white-space:nowrap;gap:1px;box-shadow:0 2px 8px #00000080}.eval-graph-tooltip-move{font-size:.72rem;font-weight:600;color:var(--color-text);font-family:var(--font-mono, monospace)}.eval-graph-tooltip-eval{font-size:.68rem;color:var(--color-text-muted);font-variant-numeric:tabular-nums}.eval-graph-tooltip-grade{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em}.game-report{display:flex;flex-direction:row;gap:1px;border:1px solid var(--color-border);border-radius:var(--radius);background:#0f1117d9;overflow:hidden;flex-shrink:0}.game-report-side{flex:1;padding:10px 12px;display:flex;flex-direction:column;gap:4px}.game-report-side--user{background:#4ade800a}.game-report-divider{width:1px;background:var(--color-border);flex-shrink:0}.game-report-header{display:flex;align-items:baseline;justify-content:space-between;gap:6px}.game-report-label{font-size:.7rem;font-weight:500;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.06em}.game-report-accuracy{font-size:1.15rem;font-weight:700;font-variant-numeric:tabular-nums;line-height:1}.game-report-acpl{font-size:.65rem;color:var(--color-text-muted);margin-top:1px}.game-report-acpl strong{color:var(--color-text);font-weight:600}.game-report-grades{display:flex;flex-wrap:wrap;gap:4px;margin-top:3px}.game-report-pill{font-size:.62rem;font-weight:600;font-family:system-ui,sans-serif;padding:2px 6px;border-radius:4px;line-height:1.3;display:inline-flex;align-items:center;gap:2px}.game-report-pill-sym{opacity:.85}.game-report-pill-count{font-variant-numeric:tabular-nums}.gr-brilliant{background:#22d3ee38;color:#22d3ee}.gr-great{background:#22c55e38;color:#22c55e}.gr-best{background:#22c55e2e;color:#4ade80}.gr-excellent{background:#4ade8026;color:#86efac}.gr-good{background:#86efac1f;color:#86efac}.gr-inaccuracy{background:#eab30838;color:#eab308}.gr-mistake{background:#f9731638;color:#fb923c}.gr-blunder{background:#ef444438;color:#ef4444}.gr-miss{background:#a78bfa38;color:#a78bfa}.load-panel{display:flex;flex-direction:column;gap:.6rem;height:100%}.import-tabs{display:flex;gap:2px;background:var(--color-surface);border-radius:var(--radius);padding:2px;flex-shrink:0}.import-tab{flex:1;background:none;border:none;border-radius:calc(var(--radius) - 2px);color:var(--color-text-muted);cursor:pointer;font-size:.78rem;padding:.3rem .4rem;transition:background .15s,color .15s}.import-tab:hover{color:var(--color-text)}.import-tab.active{background:var(--color-surface-2);color:var(--color-text);font-weight:500}.account-link{display:flex;flex-direction:column;gap:.4rem;flex-shrink:0}.account-link-row{display:flex;align-items:center;gap:.4rem}.account-link-input{flex:1;min-width:0;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text);font-size:.82rem;padding:.35rem .5rem;outline:none}.account-link-input:focus{border-color:var(--color-accent)}.account-link-input:disabled{opacity:.5}.game-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:1px;min-height:0}.game-list-empty{color:var(--color-text-muted);font-size:.82rem;padding:.5rem 0}.game-row{display:flex;flex-direction:column;gap:.4rem;padding:.4rem .5rem;background:none;border:none;border-radius:var(--radius);color:var(--color-text);cursor:pointer;font-size:.8rem;text-align:left;transition:background .12s;width:100%}.game-row:hover{background:var(--color-surface)}.game-row--loaded{border-left:2px solid var(--color-accent);background:#4a9eff0d}.game-row--loaded:hover{background:#4a9eff17}.game-row__line1{display:flex;align-items:center;gap:5px;min-width:0}.game-row__color-dot{display:inline-block;width:10px;height:10px;border-radius:50%;border:1px solid var(--border);flex-shrink:0}.game-row__color-dot[data-color=white]{background:#fff}.game-row__color-dot[data-color=black]{background:#333}.game-row__players{flex:1;display:flex;align-items:center;gap:5px;overflow:hidden;min-width:0}.game-row__username,.game-row__opponent{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.game-row__vs{color:var(--color-text-muted);font-size:.7rem;flex-shrink:0}.game-row__result{font-size:.75rem;font-weight:600;width:1.4rem;text-align:center;flex-shrink:0;border-radius:3px;padding:.1rem .2rem;margin-left:auto}.game-row__result--w{color:#4ade80}.game-row__result--l{color:#f87171}.game-row__result--d{color:var(--color-text-muted)}.game-row__line2{display:flex;align-items:center;gap:1px;font-size:.72rem;color:var(--color-text-muted);padding-left:1px}.game-row__line2-sep{margin:0 .35rem;opacity:.5}.game-row__meta{color:var(--color-text-muted);font-size:.72rem;flex-shrink:0}.game-list__load-more{background:none;border:1px solid var(--color-border, #383838);border-radius:4px;color:var(--color-text-muted);cursor:pointer;font-size:.72rem;padding:2px 8px;transition:color .15s,border-color .15s,background .12s;white-space:nowrap}.game-list__load-more:hover{color:var(--color-text);border-color:var(--color-text-muted)}.game-list__load-more:disabled{opacity:.5;cursor:default}.game-list__all-loaded{color:var(--color-text-muted);font-size:.72rem;text-align:center;padding:.3rem 0;opacity:.6}.game-list-controls{display:flex;flex-direction:column;gap:.3rem;flex-shrink:0;margin-top:-.3rem}.game-list-header{display:flex;align-items:center;gap:.5rem;flex-shrink:0;padding:0 .1rem}.game-list-count{color:var(--color-text-muted);font-size:.75rem;flex:1}.game-list-loading-status{color:var(--color-text-muted, #666);font-size:.72rem}.game-list__cancel-btn{padding:2px 8px;background:transparent;color:var(--color-text-muted, #666);border:1px solid var(--color-border, #383838);border-radius:4px;font-size:.72rem;cursor:pointer;transition:color .12s,border-color .12s;white-space:nowrap}.game-list__cancel-btn:hover{color:var(--color-text, #bbb);border-color:var(--color-text-muted, #555)}.game-filter-bar{display:flex;flex-direction:column;gap:.35rem;padding:0 .1rem;flex-shrink:0}.game-opponent-row{display:flex;gap:.3rem;align-items:center}.game-opponent-search{flex:1;min-width:0;background:var(--color-bg-secondary, #222);color:var(--color-text, #ccc);border:1px solid var(--color-border, #383838);border-radius:5px;padding:4px 8px;font-size:.78rem;outline:none;box-sizing:border-box;transition:border-color .15s}.game-opponent-search::placeholder{color:var(--color-text-muted, #555)}.game-opponent-search:focus{border-color:var(--color-accent, #4a9eff)}.game-opponent-search-btn,.game-opponent-clear-btn{padding:3px 8px!important;white-space:nowrap;font-size:.72rem}.game-opponent-search-btn{background:var(--color-accent, #4a9eff)!important;color:#fff!important;border:none!important}.game-opponent-clear-btn{background:transparent!important;color:var(--color-text-muted, #666)!important;border:1px solid var(--color-border, #383838)!important}.game-opponent-clear-btn:hover{color:var(--color-text, #bbb)!important}.game-opponent-hint{font-size:.72rem;color:var(--color-text-muted, #666);padding:0 .1rem}.game-opponent-hint-link{background:none;border:none;color:var(--color-accent, #4a9eff);font-size:inherit;cursor:pointer;padding:0;text-decoration:underline}.game-filter-row{display:flex;align-items:center;gap:.4rem;flex-wrap:wrap}.game-filter-group{display:flex;gap:2px;background:var(--color-bg-secondary, #1e1e1e);border:1px solid var(--color-border, #383838);border-radius:5px;padding:2px}.game-filter-btn{background:transparent;color:var(--color-text-muted, #666);border:none;border-radius:3px;padding:2px 7px;font-size:.72rem;cursor:pointer;line-height:1.5;transition:background .12s,color .12s;white-space:nowrap}.game-filter-btn:hover:not(.game-filter-btn--active){background:var(--color-bg-hover, #2e2e2e);color:var(--color-text, #bbb)}.game-filter-btn--active{background:var(--color-accent, #4a9eff);color:#fff}.game-sort-select{background:var(--color-bg-secondary, #1e1e1e);color:var(--color-text-muted, #888);border:1px solid var(--color-border, #383838);border-radius:5px;padding:3px 5px;font-size:.72rem;cursor:pointer;margin-left:auto;outline:none;transition:border-color .15s}.game-sort-select:focus{border-color:var(--color-accent, #4a9eff)}.game-list__load-actions{display:flex;gap:.4rem;margin-top:.25rem}.game-list__load-all{flex:1;padding:6px 0;background:transparent;color:var(--color-text-muted, #666);border:1px solid var(--color-border, #383838);border-radius:5px;font-size:.78rem;cursor:pointer;transition:background .12s,color .12s,border-color .12s}.game-list__load-all:hover:not(:disabled){background:var(--color-bg-hover, #2e2e2e);color:var(--color-text, #bbb);border-color:var(--color-text-muted, #555)}.game-list__load-all:disabled{cursor:default}.promotion-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:100;background:#00000040}.promotion-picker{position:absolute;width:12.5%;display:flex;box-shadow:0 6px 28px #0000008c,0 0 0 1px #ffffff14;overflow:hidden;border-radius:6px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.promotion-cancel{width:100%;aspect-ratio:1;background:#505050e6;border:none;cursor:pointer;font-size:.9rem;display:flex;align-items:center;justify-content:center;color:#ccc;flex-shrink:0;transition:background .12s}.promotion-cancel:hover{background:#646464f2;color:#fff}.promotion-choice{width:100%;aspect-ratio:1;background:#f5f5f0f2;border:none;border-bottom:1px solid rgba(0,0,0,.08);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .12s}.promotion-choice:hover{background:#dcebfff2}.promotion-choice:last-child{border-bottom:none}.game-row__analyzed-badge{color:#4caf50;font-size:.75rem;font-weight:700;margin-right:4px;flex-shrink:0}.game-row--cached{opacity:.88}.identity-prompt{display:flex;align-items:center;gap:8px;margin-top:6px;font-size:.78rem;color:#999}.identity-prompt__text{flex:1}.identity-prompt__yes{background:#4a7fa5;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.75rem;padding:2px 10px}.identity-prompt__yes:hover{background:#5a9abf}.identity-prompt__no{background:none;border:1px solid #555;border-radius:4px;color:#888;cursor:pointer;font-size:.75rem;padding:2px 10px}.identity-prompt__no:hover{border-color:#888;color:#bbb}.account-link-input-wrap{position:relative;flex:1;min-width:0}.account-link-input-wrap .account-link-input{width:100%;box-sizing:border-box}.account-link-input-wrap--crowned .account-link-input{padding-right:1.6rem}.identity-crown{position:absolute;right:.45rem;top:50%;transform:translateY(-61%);color:#c8a550bf;font-size:1.1rem;font-weight:700;pointer-events:none;-webkit-user-select:none;user-select:none;line-height:1}.username-suggestions{position:absolute;top:100%;left:0;right:0;background:var(--color-bg-panel, #1e1e1e);border:1px solid var(--color-border);border-top:none;border-radius:0 0 var(--radius) var(--radius);list-style:none;margin:0;padding:0;z-index:100;overflow:hidden}.username-suggestions__item{display:flex;align-items:center;padding:.3rem .5rem;font-size:.82rem;color:var(--color-text);cursor:pointer}.username-suggestions__crown{margin-left:.3rem;color:#c8a550cc;font-size:1.1rem;font-weight:700;line-height:1;position:relative;top:-.15em}.username-suggestions__item:hover{background:var(--color-border)}.auth-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:1000;display:flex;align-items:center;justify-content:center}.auth-modal{background:#1a1b23;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:2rem;width:380px;max-width:90vw;position:relative;box-shadow:0 16px 48px #00000080}.auth-close{position:absolute;top:.75rem;right:.75rem;background:none;border:none;color:#ffffff80;font-size:1.5rem;cursor:pointer;line-height:1;padding:.25rem}.auth-close:hover{color:#fff}.auth-tabs{display:flex;gap:1px;margin-bottom:1.5rem;border-bottom:1px solid rgba(255,255,255,.1)}.auth-tab{flex:1;background:none;border:none;padding:.5rem 0;font-size:.9rem;color:#ffffff80;cursor:pointer;border-bottom:2px solid transparent;transition:color .15s,border-color .15s}.auth-tab.active{color:#fff;border-bottom-color:#7c3aed}.auth-form{display:flex;flex-direction:column;gap:.75rem}.auth-input-wrap{position:relative;display:flex;align-items:center}.auth-input-wrap .auth-input{width:100%;padding-right:2.5rem}.auth-eye{position:absolute;top:50%;transform:translateY(-50%);right:.5rem;background:none;border:none;cursor:pointer;font-size:1rem;line-height:1;padding:0;opacity:.6;transition:opacity .15s;-webkit-user-select:none;user-select:none}.auth-eye:hover{opacity:1}.auth-input{padding:.6rem .75rem;background:#ffffff0f;border:1px solid rgba(255,255,255,.12);border-radius:6px;color:#fff;font-size:.9rem;outline:none}.auth-input:focus{border-color:#7c3aed}.auth-error{color:#e55;font-size:.8rem;padding:.25rem 0}.auth-requirements{display:flex;flex-direction:column;gap:.25rem;margin-top:-.25rem}.auth-req-row{display:flex;align-items:center;gap:.4rem;font-size:.78rem;transition:color .15s}.auth-req-unmet{color:#ffffff59}.auth-req-met{color:#4ade80}.auth-submit{padding:.6rem;background:#7c3aed;color:#fff;border:none;border-radius:6px;font-size:.9rem;font-weight:600;cursor:pointer;transition:opacity .15s}.auth-submit:hover{opacity:.9}.auth-submit:disabled{opacity:.6;cursor:not-allowed}.auth-divider{display:flex;align-items:center;gap:1rem;margin:1.25rem 0;color:#fff6;font-size:.8rem}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:#ffffff1a}.auth-oauth{display:flex;flex-direction:column;gap:.5rem}.auth-oauth-btn{display:block;padding:.5rem .75rem;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:#fff;font-size:.85rem;text-align:center;text-decoration:none;cursor:pointer;transition:background .15s}.auth-oauth-btn:hover{background:#ffffff1f}.nav-spacer{flex:1}.nav-user{padding:.5rem .75rem;border-top:1px solid var(--border)}.nav-user--collapsed{padding:.4rem 0;display:flex;justify-content:center}.nav-user-icon-btn{background:none;border:none;color:var(--color-text-muted);font-size:1.2rem;cursor:pointer;padding:.3rem;border-radius:4px;transition:color .15s,background .15s;line-height:1}.nav-user-icon-btn:hover{color:var(--color-text);background:#ffffff14}.nav-user--collapsed .nav-user-btn{padding:.25rem;justify-content:center;width:auto}.nav-signin-btn{width:100%;padding:.5rem;background:var(--accent);color:#fff;border:none;border-radius:6px;font-size:.85rem;cursor:pointer;transition:opacity .15s}.nav-signin-btn:hover{opacity:.9}.nav-user-btn{display:flex;align-items:center;gap:.5rem;width:100%;padding:.35rem .4rem;background:none;border:none;border-radius:6px;color:var(--text-primary);cursor:pointer;font-size:.8rem;text-align:left;transition:background .15s}.nav-user-btn:hover{background:#ffffff0f}.nav-user-btn.active{background:#ffffff1a}.nav-user-avatar-wrap{position:relative;flex-shrink:0}.nav-user-avatar{width:28px;height:28px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:600}.nav-user-avatar--img{width:28px;height:28px;border-radius:50%;object-fit:cover;background:var(--accent)}.nav-user-admin-badge{position:absolute;bottom:-4px;right:-4px;font-size:.6rem;line-height:1;pointer-events:none}.nav-user-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nav-user-logout:hover{color:#e55;border-color:#e55}.nav-sync-msg{font-size:.75rem;color:var(--accent);padding:.25rem 0;text-align:center}[data-board=blue] cg-board{background-color:#dee3e6;background-image:url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCAyIDIiIHNoYXBlLXJlbmRlcmluZz0iY3Jpc3BFZGdlcyI+PHJlY3Qgd2lkdGg9IjIiIGhlaWdodD0iMiIgZmlsbD0iI2RlZTNlNiIvPjxyZWN0IHg9IjEiIHk9IjAiIHdpZHRoPSIxIiBoZWlnaHQ9IjEiIGZpbGw9IiM4Y2EyYWQiLz48cmVjdCB4PSIwIiB5PSIxIiB3aWR0aD0iMSIgaGVpZ2h0PSIxIiBmaWxsPSIjOGNhMmFkIi8+PC9zdmc+);background-size:25% 25%}[data-board=green] cg-board{background-color:#ffd;background-image:url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCAyIDIiIHNoYXBlLXJlbmRlcmluZz0iY3Jpc3BFZGdlcyI+PHJlY3Qgd2lkdGg9IjIiIGhlaWdodD0iMiIgZmlsbD0iI2ZmZmZkZCIvPjxyZWN0IHg9IjEiIHk9IjAiIHdpZHRoPSIxIiBoZWlnaHQ9IjEiIGZpbGw9IiM4NmE2NjYiLz48cmVjdCB4PSIwIiB5PSIxIiB3aWR0aD0iMSIgaGVpZ2h0PSIxIiBmaWxsPSIjODZhNjY2Ii8+PC9zdmc+);background-size:25% 25%}[data-board=purple] cg-board{background-color:#e8d0e0;background-image:url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCAyIDIiIHNoYXBlLXJlbmRlcmluZz0iY3Jpc3BFZGdlcyI+PHJlY3Qgd2lkdGg9IjIiIGhlaWdodD0iMiIgZmlsbD0iI2U4ZDBlMCIvPjxyZWN0IHg9IjEiIHk9IjAiIHdpZHRoPSIxIiBoZWlnaHQ9IjEiIGZpbGw9IiM5YzZiOWMiLz48cmVjdCB4PSIwIiB5PSIxIiB3aWR0aD0iMSIgaGVpZ2h0PSIxIiBmaWxsPSIjOWM2YjljIi8+PC9zdmc+);background-size:25% 25%}.profile-page{flex:1;padding:2rem;overflow-y:auto;max-width:640px}.profile-title{font-size:1.4rem;font-weight:700;color:var(--color-text);margin-bottom:1.5rem}.profile-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:1.25rem 1.5rem;margin-bottom:1rem}.profile-section-title{font-size:.9rem;font-weight:600;color:var(--color-text);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.75rem}.profile-section-desc{font-size:.82rem;color:var(--color-text-muted);margin-bottom:.75rem}.profile-info-grid{display:flex;flex-direction:column;gap:.4rem}.profile-info-row{display:flex;gap:1rem;font-size:.875rem}.profile-info-label{color:var(--color-text-muted);min-width:100px;flex-shrink:0}.profile-info-value{color:var(--color-text);font-weight:500}.profile-guest-note{font-size:.85rem;color:var(--color-text-muted);font-style:italic}.profile-field-group{display:flex;flex-direction:column;gap:.85rem}.profile-field{display:flex;flex-direction:column;gap:.35rem}.profile-field-label{font-size:.78rem;font-weight:500;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em}.profile-input{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text);font-size:.875rem;padding:.45rem .65rem;outline:none;width:100%;max-width:320px}.profile-input:focus{border-color:var(--color-accent)}.profile-input:disabled{opacity:.45;cursor:not-allowed}.profile-input--short{max-width:120px}.profile-field-row{display:flex;align-items:center;gap:.75rem}.profile-msg{font-size:.8rem;font-weight:500}.profile-msg--ok{color:#4ade80}.profile-msg--err{color:#f87171}.profile-help-text{font-size:.75rem;color:var(--color-text-muted);margin-top:.15rem}.profile-toggle-group{display:flex;gap:1px;border:1px solid var(--color-border);border-radius:var(--radius);overflow:hidden;width:fit-content}.profile-toggle-btn{padding:.35rem 1rem;background:none;border:none;color:var(--color-text-muted);font-size:.82rem;font-weight:500;cursor:pointer;transition:background .15s,color .15s}.profile-toggle-btn+.profile-toggle-btn{border-left:1px solid var(--color-border)}.profile-toggle-btn:hover{background:var(--color-surface-2);color:var(--color-text)}.profile-toggle-btn.active{background:var(--color-accent);color:#fff}.profile-board-themes{display:flex;gap:.6rem;flex-wrap:wrap}.profile-board-swatch{display:flex;flex-direction:column;align-items:center;gap:.3rem;background:none;border:2px solid var(--color-border);border-radius:var(--radius);padding:.3rem;cursor:pointer;transition:border-color .15s;width:60px}.profile-board-swatch:hover{border-color:var(--color-text-muted)}.profile-board-swatch.active{border-color:var(--color-accent)}.swatch-half{display:block;width:40px;height:16px}.swatch-light{border-radius:3px 3px 0 0}.swatch-dark{border-radius:0 0 3px 3px}.swatch-label{font-size:.65rem;color:var(--color-text-muted);white-space:nowrap}.coach-panel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);display:flex;flex-direction:column;overflow:hidden;flex-shrink:0;margin-bottom:.5rem}.coach-panel--empty{padding:1rem;text-align:center}.coach-panel__empty-msg{font-size:.82rem;color:var(--color-text-muted)}.coach-panel__nav{display:flex;align-items:center;gap:.5rem;padding:.4rem .6rem;border-bottom:1px solid var(--color-border);background:#4a9eff0d;flex-shrink:0}.coach-panel__nav-btn{background:none;border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text-muted);cursor:pointer;font-size:.85rem;line-height:1;padding:.15rem .45rem;transition:border-color .12s,color .12s}.coach-panel__nav-btn:hover:not(:disabled){border-color:var(--color-accent);color:var(--color-accent)}.coach-panel__nav-btn:disabled{opacity:.3;cursor:default}.coach-panel__nav-label{flex:1;text-align:center;font-size:.75rem;font-weight:600;color:var(--color-accent);letter-spacing:.02em;text-transform:uppercase}.coach-panel__content{padding:.75rem;overflow-y:auto;max-height:400px}.coach-panel__loading{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1rem;color:var(--color-text-muted);font-size:.82rem}.coach-panel__spinner{display:inline-block;width:18px;height:18px;border:2px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;animation:coach-spin .7s linear infinite;flex-shrink:0}@keyframes coach-spin{to{transform:rotate(360deg)}}.coach-panel__error{padding:.6rem;background:#ff505014;border:1px solid rgba(255,80,80,.25);border-radius:var(--radius);font-size:.8rem;color:#ff8080}.coach-panel__no-lesson-msg{font-size:.82rem;color:var(--color-text-muted);font-style:italic;text-align:center;padding:.5rem 0}.coach-panel__checklist{background:#ffb43214;border:1px solid rgba(255,180,50,.25);border-radius:6px;padding:.6rem .75rem;margin-bottom:.5rem}.coach-panel__checklist-label{font-size:.78rem;font-weight:600;color:var(--color-text-secondary);margin:0 0 .35rem;text-transform:uppercase;letter-spacing:.03em}.coach-panel__checklist-questions{margin:0;padding-left:1.2rem;font-size:.82rem;line-height:1.6;color:var(--color-text)}.coach-panel__checklist-questions li{margin-bottom:.15rem}.lesson-card{display:flex;flex-direction:column;gap:.6rem}.lesson-card__header{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;padding-bottom:.5rem;border-bottom:1px solid var(--color-border)}.lesson-card__move{font-size:.72rem;font-weight:700;background:var(--color-surface-2);color:var(--color-text-muted);border-radius:var(--radius);padding:.15rem .45rem;letter-spacing:.03em;text-transform:uppercase}.lesson-card__principle{font-size:.72rem;font-weight:700;letter-spacing:.02em;text-transform:uppercase;border:1px solid currentColor;border-radius:999px;padding:.16rem .5rem}.lesson-card__confidence{font-size:.7rem;color:var(--color-accent);opacity:.7;letter-spacing:.05em}.lesson-card__body{display:flex;flex-direction:column;gap:.4rem}.lesson-card__para{font-size:.83rem;color:var(--color-text);line-height:1.55;margin:0}.lesson-card__para:last-child{margin-bottom:0}.lesson-card__steps{display:flex;flex-direction:column;gap:.55rem}.lesson-card__step{display:flex;align-items:flex-start;gap:.5rem;line-height:1.45}.lesson-card__step-icon{font-size:.95rem;flex-shrink:0;width:1.4rem;text-align:center;margin-top:.05rem}.lesson-card__step-text{font-size:.83rem;color:var(--color-text);flex:1}.socratic-prompt{display:flex;flex-direction:column;gap:.65rem}.socratic-prompt__header{display:flex;align-items:flex-start;gap:.5rem}.socratic-prompt__icon{font-size:1.1rem;flex-shrink:0}.socratic-prompt__intro{font-size:.83rem;color:var(--color-text);font-weight:500;line-height:1.4}.socratic-prompt__questions{list-style:none;padding:0;display:flex;flex-direction:column;gap:.4rem;counter-reset:q-counter}.socratic-prompt__question{display:flex;align-items:flex-start;gap:.5rem;font-size:.81rem;color:var(--color-text-muted);line-height:1.45;counter-increment:q-counter;padding:.35rem .5rem;background:#4a9eff0a;border-left:2px solid var(--color-border);border-radius:0 var(--radius) var(--radius) 0}.socratic-prompt__question:before{content:counter(q-counter) ".";color:var(--color-accent);font-weight:700;font-size:.78rem;flex-shrink:0;min-width:1rem}.socratic-prompt__reveal-btn{align-self:flex-start;background:var(--color-accent);color:#fff;border:none;border-radius:var(--radius);padding:.4rem .85rem;font-size:.82rem;font-weight:600;cursor:pointer;transition:background .15s;margin-top:.1rem}.socratic-prompt__reveal-btn:hover{background:var(--color-accent-hover)}.coach-panel__admin{margin-top:.75rem;padding:.5rem .75rem;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:.35rem}.coach-panel__reset-btn{background:#dc323226;border:1px solid rgba(220,50,50,.35);border-radius:6px;color:#f87171;font-size:.78rem;padding:.35rem .6rem;cursor:pointer;transition:background .15s}.coach-panel__reset-btn:hover:not(:disabled){background:#dc323247}.coach-panel__reset-btn:disabled{opacity:.5;cursor:not-allowed}.coach-panel__reset-msg{font-size:.75rem;color:#a3e635;margin:0}.profile-admin-badge{display:inline-flex;align-items:center;gap:.3rem;background:#7c3aed33;border:1px solid rgba(124,58,237,.4);color:#c4b5fd;font-size:.78rem;font-weight:600;padding:.15rem .55rem;border-radius:999px}.profile-admin-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.9rem}.profile-admin-card{display:flex;flex-direction:column;gap:.65rem;padding:.9rem 1rem;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:10px}.profile-admin-card--wide{grid-column:1 / -1}.profile-admin-label{font-size:.74rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.profile-admin-value{font-size:1.05rem;color:var(--color-text)}.profile-admin-value.is-live{color:#86efac}.profile-admin-actions{display:flex;flex-wrap:wrap;gap:.55rem}.profile-admin-stats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.75rem}.profile-admin-stat{display:flex;flex-direction:column;gap:.3rem;padding:.7rem .8rem;background:#ffffff08;border-radius:8px}.profile-admin-stat span{font-size:.72rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em}.profile-admin-stat strong{font-size:1rem;color:var(--color-text)}.profile-admin-message{margin-top:.75rem;font-size:.84rem;color:#86efac}.profile-admin-message.is-error{color:#fca5a5}.profile-ratings-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem;margin-top:.25rem}@media (max-width: 760px){.profile-admin-grid{grid-template-columns:1fr}.profile-admin-stats{grid-template-columns:repeat(2,minmax(0,1fr))}}.profile-rating-item{display:flex;flex-direction:column;gap:.4rem;padding:.6rem .75rem;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:8px}.profile-rating-mode{font-size:.72rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.profile-rating-value{font-size:1.35rem;font-weight:700;color:var(--color-text);line-height:1.2}.opening-label{font-size:.8rem;color:var(--color-text-muted);text-align:center;padding:.2rem .5rem;opacity:.85;min-height:1.2rem}.player-info-placeholder{pointer-events:none}.transcript-list{padding:.5rem .25rem;display:flex;flex-direction:column;gap:1px}.transcript-pair{display:flex;align-items:center;gap:.3rem;padding:.15rem .25rem;font-size:.9rem}.transcript-pair:hover{background:#ffffff0a;border-radius:4px}.transcript-movenum{color:var(--color-text-muted);font-size:.8rem;min-width:1.6rem;text-align:right;flex-shrink:0}.transcript-san{padding:.1rem .35rem;border-radius:3px;cursor:pointer;color:var(--color-text);min-width:3.2rem;transition:background .1s}.transcript-san:hover{background:#ffffff1a}.transcript-san.transcript-active{background:var(--color-accent, #4a9eff);color:#fff;font-weight:600}.play-page{display:flex;flex:1;min-height:0;gap:1rem}.play-page--setup{align-items:center;justify-content:center}.play-setup-wrapper{display:flex;gap:2.5rem;align-items:flex-start;padding:2rem}.play-setup-board-preview{display:flex;flex-direction:column;gap:.5rem}.play-setup-board-controls{display:flex;align-items:center;gap:.75rem;font-size:.85rem;color:var(--color-text-muted, #aaa)}.play-setup-orientation-hint{font-size:.85rem;color:var(--color-text-muted, #aaa)}.play-setup-panel{display:flex;flex-direction:column;gap:1.5rem;min-width:280px;max-width:340px;padding:1.5rem;background:var(--color-panel, #1e1e1e);border-radius:8px;border:1px solid var(--color-border, #333)}.play-setup-title{font-size:1.3rem;font-weight:700;margin:0}.play-setup-section{display:flex;flex-direction:column;gap:.5rem}.play-setup-label{font-size:.78rem;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted, #aaa);font-weight:600}.play-setup-elo-display{display:flex;align-items:baseline;gap:.4rem;margin-bottom:.25rem}.play-setup-elo-number{font-size:1.4rem;font-weight:700}.play-setup-elo-label{font-size:.9rem;color:var(--color-text-muted, #aaa)}.play-setup-slider{width:100%;accent-color:var(--color-accent, #4a9eff);cursor:pointer}.play-setup-slider-ticks{display:flex;justify-content:space-between;font-size:.72rem;color:var(--color-text-muted, #aaa)}.play-setup-pills{display:flex;gap:.4rem;flex-wrap:wrap}.play-setup-pill{padding:.35rem .85rem;border-radius:20px;border:1px solid var(--color-border, #444);background:transparent;color:var(--color-text, #eee);font-size:.85rem;cursor:pointer;transition:background .12s,border-color .12s}.play-setup-pill:hover{border-color:var(--color-accent, #4a9eff)}.play-setup-pill.active{background:var(--color-accent, #4a9eff);border-color:var(--color-accent, #4a9eff);color:#fff;font-weight:600}.play-setup-pill--disabled,.play-setup-pill--disabled:hover{opacity:.4;cursor:not-allowed;border-color:var(--color-border, #444)}.play-setup-start-btn{padding:.7rem 1.2rem;border-radius:6px;border:none;background:var(--color-accent, #4a9eff);color:#fff;font-size:1rem;font-weight:700;cursor:pointer;transition:opacity .15s;margin-top:.5rem}.play-setup-start-btn:hover{opacity:.88}.play-board-controls{gap:.5rem}.bot-thinking-indicator{padding:.4rem .75rem;background:#ffffff0a;border-radius:6px;font-size:.82rem;color:var(--color-text-muted, #aaa);text-align:center;margin-bottom:.5rem}.bot-thinking-dots:after{content:"";animation:thinking-dots 1.2s steps(4,end) infinite}@keyframes thinking-dots{0%{content:""}25%{content:"."}50%{content:".."}75%{content:"..."}to{content:""}}.game-result-banner{margin-top:.75rem;padding:1.25rem 1.25rem 1.5rem;border-radius:10px;border-top:3px solid transparent;background:var(--color-panel, #1e1e1e);text-align:center;display:flex;flex-direction:column;align-items:center;gap:.35rem}.game-result-banner--win{border-top-color:#4ade80;background:#4ade800d}.game-result-banner--loss{border-top-color:#f87171;background:#f871710d}.game-result-banner--draw{border-top-color:#94a3b8;background:#94a3b80d}.game-result-icon{font-size:2rem;line-height:1;margin-bottom:.1rem}.game-result-banner--win .game-result-icon{color:#4ade80}.game-result-banner--loss .game-result-icon{color:#f87171}.game-result-banner--draw .game-result-icon{color:#94a3b8}.game-result-title{font-size:1.6rem;font-weight:700;letter-spacing:-.01em}.game-result-subtitle{font-size:.82rem;color:var(--color-text-muted, #aaa);text-transform:capitalize;margin-bottom:.25rem}.game-result-actions{display:flex;gap:.6rem;justify-content:center;margin-top:.5rem;width:100%}.game-result-btn{flex:1;padding:.55rem .75rem;border-radius:6px;border:1px solid var(--color-border, #444);font-size:.85rem;cursor:pointer;transition:opacity .12s}.game-result-btn--primary{background:var(--color-accent, #4a9eff);border-color:var(--color-accent, #4a9eff);color:#fff;font-weight:600}.game-result-btn--secondary{background:transparent;color:var(--color-text, #eee)}.game-result-btn:hover{opacity:.82}.browse-mode-banner{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.4rem .75rem;background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius);margin-bottom:.5rem;font-size:.8rem;color:var(--color-text-muted)}.play-eval-lines{display:flex;flex-direction:column;gap:.25rem;padding:.5rem;border:1px solid var(--color-border);border-radius:var(--radius);margin-top:.5rem;font-size:.8rem}.play-eval-line{display:flex;align-items:baseline;gap:.5rem}.play-eval-score{font-weight:600;color:var(--color-accent);min-width:3rem;font-variant-numeric:tabular-nums}.play-eval-moves{color:var(--color-text-muted);font-family:var(--font-mono, monospace);font-size:.75rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.btn-danger{color:var(--color-error, #f87171);border-color:var(--color-error, #f87171)}.btn-danger:hover{background:var(--color-error, #f87171);color:#fff}.coach-panel{display:flex;flex-direction:column;height:100%;overflow:hidden}.coach-panel--empty{justify-content:center;align-items:center;padding:2rem 1rem;text-align:center}.coach-panel__analyzing-bar{display:flex;align-items:center;gap:.5rem;padding:.4rem .75rem;background:var(--color-surface-2, rgba(255,255,255,.04));border-bottom:1px solid var(--color-border);font-size:.8rem;color:var(--color-text-muted);flex-shrink:0}.coach-narrative{overflow-y:auto;flex:1;padding:.25rem 0}.coach-narrative__move-pair{display:flex;flex-direction:column}.coach-narrative__row{display:flex;flex-direction:column;padding:.2rem .75rem;border-left:2px solid transparent;transition:background .1s}.coach-narrative__row:hover{background:var(--color-surface-2, rgba(255,255,255,.03))}.coach-narrative__row--critical{border-left-color:var(--color-accent, #f59e0b);background:#f59e0b0a;padding-top:.5rem;padding-bottom:.5rem;margin:.25rem 0}.coach-narrative__move-btn{background:none;border:none;cursor:pointer;display:flex;align-items:center;gap:.35rem;padding:0;text-align:left;width:100%;color:var(--color-text)}.coach-narrative__move-label{font-family:var(--font-mono, monospace);font-size:.82rem;font-weight:500;white-space:nowrap}.coach-narrative__move-btn:hover .coach-narrative__move-label{color:var(--color-accent, #f59e0b)}.coach-narrative__grade{font-size:.75rem;font-weight:700;line-height:1}.coach-narrative__grade--brilliant{color:#c084fc}.coach-narrative__grade--great,.coach-narrative__grade--best{color:#34d399}.coach-narrative__grade--excellent{color:#6ee7b7}.coach-narrative__grade--good{color:var(--color-text-muted)}.coach-narrative__grade--inaccuracy{color:#fbbf24}.coach-narrative__grade--mistake{color:#f97316}.coach-narrative__grade--blunder{color:#ef4444}.coach-narrative__grade--miss{color:#f97316}.coach-narrative__category-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;margin-left:2px}.coach-narrative__comment{font-size:.76rem;color:var(--color-text-muted);margin:.1rem 0 0;line-height:1.4}.coach-narrative__lesson{margin-top:.5rem}.coach-panel__loading--inline{display:flex;align-items:center;gap:.5rem;font-size:.8rem;color:var(--color-text-muted);padding:.4rem 0}.coach-panel__error-inline{font-size:.78rem;color:var(--color-error, #f87171);margin:.25rem 0 0}.coach-panel__empty-msg--inline{font-size:.82rem;color:var(--color-text-muted);padding:1rem .75rem;margin:0}.coach-panel__spinner--small{width:12px;height:12px;border-width:2px}.move-coach-comment{padding:.5rem .75rem;border-radius:var(--radius);background:var(--color-surface-2, rgba(255,255,255,.03));border:1px solid var(--color-border);margin:0 0 .5rem;min-height:2.5rem;transition:border-color .15s}.move-coach-comment--critical{border-color:var(--color-accent, #f59e0b);background:#f59e0b0d}.move-coach-comment__badge{display:inline-flex;align-items:center;font-size:.67rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:.1rem .35rem;border-radius:3px;border:1px solid currentColor;white-space:nowrap;flex-shrink:0}.move-coach-comment__text{font-size:.8rem;color:var(--color-text-muted);margin:0;line-height:1.45}.move-coach-comment__lesson{margin-top:.4rem;padding-top:.4rem;border-top:1px solid var(--color-border)}.move-coach-comment__lesson-text{font-size:.82rem;color:var(--color-text);margin:0;line-height:1.55}.move-coach-comment__loading{font-size:.78rem;color:var(--color-text-muted);margin:0;font-style:italic}.move-coach-comment__error{font-size:.78rem;color:var(--color-error, #f87171);margin:0}.game-transcript{overflow-y:auto;flex:1;min-height:0;padding:.25rem 0;font-size:.82rem}.game-transcript--empty{display:flex;align-items:center;justify-content:center;padding:1.5rem 1rem}.game-transcript__placeholder{color:var(--color-text-muted);font-size:.8rem;margin:0;text-align:center}.transcript-pair{display:flex;align-items:flex-start;gap:.25rem;padding:0 .5rem}.transcript-pair__num{font-variant-numeric:tabular-nums;color:var(--color-text-muted);min-width:1.8rem;padding-top:.25rem;font-size:.75rem;flex-shrink:0}.transcript-pair__moves{display:flex;flex:1;gap:.15rem;flex-wrap:wrap}.transcript-move{flex:1;min-width:0;border-radius:4px;padding:.2rem .35rem;transition:background .1s}.transcript-move--active{background:var(--color-surface-active, rgba(255, 255, 255, .1))}.transcript-move--critical{border-left:2px solid var(--color-accent, #f59e0b)}.transcript-move__token-row{display:flex;align-items:center;gap:.3rem}.transcript-move__btn{background:none;border:none;cursor:pointer;display:flex;align-items:center;gap:.25rem;padding:0;color:var(--color-text);font-size:.82rem}.transcript-move__btn:hover .transcript-move__san{color:var(--color-accent, #f59e0b)}.transcript-move__san{font-family:var(--font-mono, monospace);font-weight:500}.transcript-move__grade{font-size:.72rem;font-weight:700;line-height:1}.transcript-move__dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.transcript-move__lesson-btn{background:none;border:none;cursor:pointer;font-size:.65rem;color:var(--color-text-muted);padding:0 .2rem;line-height:1;margin-left:auto;opacity:.7}.transcript-move__lesson-btn:hover{opacity:1;color:var(--color-accent, #f59e0b)}.transcript-move__comment{font-size:.73rem;color:var(--color-text-muted);margin:.1rem 0 0;line-height:1.4}.transcript-move__lesson{margin-top:.4rem;padding:.5rem .6rem;background:var(--color-surface-2, rgba(255,255,255,.04));border-radius:4px;border:1px solid var(--color-border)}.transcript-move__lesson-badge{display:inline-block;font-size:.68rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;padding:.1rem .35rem;border-radius:3px;border:1px solid currentColor;margin-bottom:.35rem}.transcript-move__lesson-text{font-size:.8rem;color:var(--color-text);margin:0;line-height:1.55}.transcript-move__lesson-loading,.transcript-move__lesson-error{font-size:.78rem;margin:0;font-style:italic}.transcript-move__lesson-error{color:var(--color-error, #f87171)}.transcript-move__lesson-loading{color:var(--color-text-muted)}.move-coach-comment--idle{min-height:3rem}.move-coach-comment__idle-text{color:var(--color-text-muted);font-size:.78rem;margin:0;font-style:italic}.move-coach-comment__view-lesson-btn{display:inline-block;margin-top:.5rem;background:none;border:1px solid var(--color-border);border-radius:4px;padding:.25rem .6rem;font-size:.75rem;color:var(--color-text-muted);cursor:pointer;transition:border-color .15s,color .15s}.move-coach-comment__view-lesson-btn:hover{color:var(--color-accent, #f59e0b);border-color:var(--color-accent, #f59e0b)}.move-coach-comment__best-move-btn{margin-top:.5rem;padding:.3rem .75rem;font-size:.78rem;font-weight:500;color:#a0c4ff;background:transparent;border:1px solid rgba(160,196,255,.35);border-radius:4px;cursor:pointer;transition:color .15s,border-color .15s,background .15s}.move-coach-comment__best-move-btn:hover{color:#fff;border-color:#a0c4ffb3;background:#a0c4ff14}.lesson-nav{display:flex;align-items:center;gap:.4rem;flex-shrink:0;flex-wrap:wrap}.lesson-nav__label{font-size:.7rem;color:var(--color-text-muted, #64748b);white-space:nowrap;flex-shrink:0}.lesson-nav__next-btn{background:none;border:none;color:var(--color-text-muted, #64748b);font-size:.7rem;cursor:pointer;padding:0 .2rem;white-space:nowrap;transition:color .15s}.lesson-nav__next-btn:hover{color:var(--color-accent, #f59e0b)}.lesson-dots{display:flex;align-items:center;gap:.3rem;flex-shrink:0}.lesson-dot{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;border:1.5px solid var(--color-border, rgba(255,255,255,.15));background:transparent;color:var(--color-text-muted, #64748b);font-size:.62rem;font-weight:700;cursor:pointer;transition:border-color .15s,color .15s,background .15s;padding:0;line-height:1}.lesson-dot:hover{border-color:var(--dot-color);color:var(--dot-color)}.lesson-dot--active{border-color:var(--dot-color);color:var(--dot-color);background:color-mix(in srgb,var(--dot-color) 16%,transparent)}.lesson-dot--loading{opacity:.45;animation:lesson-dot-pulse 1.2s ease-in-out infinite}@keyframes lesson-dot-pulse{0%,to{opacity:.45}50%{opacity:.8}}.lesson-dot__num{line-height:1}.lesson-dot__spinner{display:inline-block;width:8px;height:8px;border:1.5px solid currentColor;border-top-color:transparent;border-radius:50%;animation:lesson-dot-spin .7s linear infinite}@keyframes lesson-dot-spin{to{transform:rotate(360deg)}}.move-coach-comment__header{display:flex;align-items:flex-start;justify-content:space-between;gap:.5rem}.move-coach-comment__header-text{flex:1;min-width:0;font-size:.8rem;color:var(--color-text-muted, #94a3b8);display:flex;align-items:center;gap:.4rem;flex-wrap:wrap}.move-coach-comment__analyzing-dot{display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--color-accent, #f59e0b);animation:coach-analyzing-pulse 1.2s ease-in-out infinite;flex-shrink:0}@keyframes coach-analyzing-pulse{0%,to{opacity:1}50%{opacity:.3}}.practice-page{display:grid;grid-template-columns:minmax(280px,340px) minmax(0,1fr);gap:1.25rem;width:100%;align-items:start}.practice-sidebar,.practice-main{min-width:0}.practice-sidebar{display:grid;gap:1rem}.practice-sidebar__section,.practice-hero,.practice-browser,.practice-study__board,.practice-study__notes{background:linear-gradient(180deg,#171d2bf5,#10141ff5);border:1px solid rgba(122,137,173,.18);border-radius:20px;box-shadow:0 16px 36px #0000002e}.practice-sidebar__section{padding:1rem}.practice-eyebrow,.practice-section-label,.practice-course-card__meta,.practice-line-card__meta,.practice-stat__label,.practice-alt-box__label,.practice-progress-pill{letter-spacing:.08em;text-transform:uppercase;font-size:.74rem;font-weight:700}.practice-eyebrow,.practice-section-label,.practice-course-card__meta,.practice-line-card__meta,.practice-stat__label,.practice-alt-box__label{color:#96a4c6}.practice-title,.practice-hero__title,.practice-study__title{margin:0;color:#f7f8fb}.practice-title{font-size:2rem;line-height:1.05;margin-top:.25rem}.practice-copy,.practice-hero__copy,.practice-study__summary,.practice-target-explanation,.practice-line-card__summary,.practice-course-card__subtitle{color:#c9d1e4;line-height:1.55}.practice-copy,.practice-course-card__subtitle,.practice-line-card__summary,.practice-target-explanation{font-size:.95rem}.practice-course-list,.practice-line-list,.practice-coming-soon{display:grid;gap:.75rem}.practice-course-card,.practice-line-card,.practice-chip,.practice-mode-tab{border:1px solid rgba(140,155,194,.18);background:#ffffff08;color:#eef2fb;transition:border-color .12s ease,background .12s ease,transform .12s ease}.practice-course-card,.practice-line-card{width:100%;border-radius:16px;padding:.9rem 1rem;text-align:left;cursor:pointer}.practice-course-card:hover,.practice-line-card:hover,.practice-chip:hover,.practice-mode-tab:hover:not(:disabled){border-color:#78c7be8c;background:#78c7be14;transform:translateY(-1px)}.practice-course-card.active,.practice-line-card.active,.practice-chip.active,.practice-mode-tab.active{border-color:#78c7bee6;background:linear-gradient(180deg,#54baab2e,#54baab14)}.practice-course-card__top,.practice-line-card__top,.practice-study__header,.practice-hero{display:flex;align-items:start;justify-content:space-between;gap:.75rem}.practice-course-card__badge{display:inline-flex;align-items:center;border-radius:999px;background:#5970ff2e;color:#cfd8ff;padding:.18rem .5rem;font-size:.72rem;font-weight:700}.practice-course-card__title,.practice-line-card__title,.practice-target-move,.practice-stat__value{font-weight:700;color:#f6f8fc}.practice-course-card__title,.practice-line-card__title{font-size:1rem}.practice-coming-soon__item{padding:.7rem .8rem;border-radius:14px;background:#ffffff09;color:#d6dcef}.practice-main{display:grid;gap:1rem}.practice-hero{padding:1.1rem 1.2rem}.practice-hero__title{font-size:1.7rem}.practice-hero__copy{margin:.45rem 0 0;max-width:52rem}.practice-hero__stats{display:flex;gap:.75rem;flex-wrap:wrap}.practice-stat{min-width:96px;padding:.75rem .9rem;border-radius:16px;background:#ffffff0a}.practice-stat__value{display:block;margin-top:.18rem;font-size:1.1rem}.practice-mode-tabs{display:inline-flex;gap:.55rem}.practice-mode-tab{border-radius:999px;padding:.65rem 1rem;font-weight:700;cursor:pointer}.practice-mode-tab--disabled{opacity:.55;cursor:not-allowed}.practice-workspace{display:grid;grid-template-columns:minmax(280px,360px) minmax(0,1fr);gap:1rem;align-items:start}.practice-browser,.practice-study__board,.practice-study__notes{padding:1rem}.practice-chip-row{display:flex;flex-wrap:wrap;gap:.55rem;margin-bottom:1rem}.practice-chip{border-radius:999px;padding:.55rem .85rem;font-weight:700;cursor:pointer}.practice-study{display:grid;grid-template-columns:minmax(320px,1.05fr) minmax(280px,.95fr);gap:1rem;align-items:start}.practice-progress-pill{display:inline-flex;align-items:center;border-radius:999px;padding:.45rem .7rem;background:#78c7be1f;color:#bfe7e0}.practice-board-shell{position:relative;width:min(100%,540px);aspect-ratio:1;margin:1rem 0 .9rem}.practice-history{display:flex;flex-wrap:wrap;gap:.5rem}.practice-history__move,.practice-history__empty{padding:.35rem .55rem;border-radius:999px;background:#ffffff0d;color:#dce3f5;font-size:.88rem}.practice-history__empty{color:#95a2c3}.practice-target-move{font-size:2.2rem;line-height:1;margin-top:.35rem}.practice-target-explanation{margin:.75rem 0 0}.practice-feedback{margin-top:.95rem;padding:.85rem .95rem;border-radius:16px;background:#ffffff0a;color:#d5dcf0;line-height:1.5}.practice-feedback--success{background:#54baab24;color:#ddfaf4}.practice-alt-box{margin-top:1rem;padding:.85rem;border-radius:16px;background:#ffffff0a}.practice-alt-box__item{display:grid;gap:.28rem;color:#d5dcf0}.practice-alt-box__item+.practice-alt-box__item{margin-top:.7rem}.practice-alt-box__move{font-weight:700;color:#f6f8fc}.practice-nav{display:flex;gap:.75rem;margin-top:1.2rem}.practice-nav__btn{min-width:140px}@media (max-width: 1279px){.practice-page,.practice-workspace,.practice-study{grid-template-columns:1fr}.practice-board-shell{width:min(100%,480px)}}@media (max-width: 639px){.practice-page{gap:.9rem}.practice-sidebar__section,.practice-hero,.practice-browser,.practice-study__board,.practice-study__notes{padding:.9rem;border-radius:18px}.practice-title{font-size:1.6rem}.practice-hero__title{font-size:1.4rem}.practice-study__header,.practice-hero,.practice-nav{flex-direction:column}}.practice-side-content{overflow-y:auto;padding-right:.2rem}.practice-panel-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:.85rem;display:flex;flex-direction:column;gap:.7rem}.practice-mode-toggle,.practice-panel-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.5rem}.practice-mode-toggle__btn,.practice-panel-actions .board-control-btn{width:100%;justify-content:center}.practice-panel-actions__wide{grid-column:1 / -1;justify-content:center}.practice-panel-card__eyebrow,.practice-panel-section-label,.practice-panel-stat__label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted)}.practice-panel-card__title{margin:0;color:var(--color-text);font-size:1.15rem}.practice-panel-copy{margin:0;color:var(--color-text-muted);line-height:1.5;font-size:.92rem}.practice-panel-section-label:not(:first-child){margin-top:.15rem}.practice-panel-stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.5rem}.practice-panel-stat{background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius);padding:.6rem}.practice-panel-stat__value{display:block;margin-top:.18rem;color:var(--color-text);font-weight:700}.practice-course-card,.practice-line-card{background:var(--color-surface-2);border:1px solid var(--color-border);box-shadow:none}.practice-course-card:hover,.practice-line-card:hover,.practice-chip:hover,.practice-mode-tab:hover:not(:disabled){border-color:var(--color-accent);background:#4a9eff14}.practice-course-card.active,.practice-line-card.active,.practice-chip.active,.practice-mode-tab.active{border-color:var(--color-accent);background:#4a9eff1f}.practice-course-card__title,.practice-line-card__title,.practice-target-move{color:var(--color-text)}.practice-course-card__subtitle,.practice-line-card__summary,.practice-line-card__status,.practice-history__move,.practice-history__empty,.practice-alt-box__item,.practice-coming-soon__item{color:var(--color-text-muted)}.practice-line-card__status{margin-top:.55rem;font-size:.76rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.practice-line-panel{min-height:0}.practice-line-list{max-height:none;overflow-y:visible;padding-right:.2rem}.practice-board-controls .board-controls__actions{justify-content:flex-end}.practice-mode-hint{flex:1 1 100%}.practice-feedback{background:#ffffff0a;color:var(--color-text-muted)}.practice-feedback--success{background:#4ade8021;color:#d4fae4}.practice-alt-box{background:var(--color-surface-2);border:1px solid var(--color-border)}@keyframes practice-flash-correct{0%{box-shadow:inset 0 0 0 4px #4ade8000}25%{box-shadow:inset 0 0 0 6px #4ade80b8}to{box-shadow:inset 0 0 0 4px #4ade8000}}@keyframes practice-flash-incorrect{0%{box-shadow:inset 0 0 0 4px #ef444400}25%{box-shadow:inset 0 0 0 6px #ef4444b8}to{box-shadow:inset 0 0 0 4px #ef444400}}.practice-board-flash-wrap{position:relative;border-radius:4px;overflow:hidden}.practice-board-flash--correct{animation:practice-flash-correct .55s ease-out forwards}.practice-board-flash--incorrect{animation:practice-flash-incorrect .55s ease-out forwards}.practice-feedback--incorrect{background:#ef44441f;color:#fdd5d5}.practice-feedback--revealed{background:#4a9eff1f;color:var(--color-text)}.practice-notation{display:flex;flex-wrap:wrap;gap:1px;font-size:.9rem;line-height:2}.practice-notation-pair{display:inline-flex;align-items:baseline;gap:.2rem;margin-right:.5rem}.practice-notation__num{color:var(--color-text-muted);font-size:.78rem;min-width:1.4rem}.practice-notation-san{padding:.05rem .28rem;border-radius:3px;color:var(--color-text-muted);line-height:1.8}.practice-notation-san--user{color:var(--color-text);cursor:pointer}.practice-notation-san--user:hover{background:#4a9eff1a;color:var(--color-accent)}.practice-notation-san--current{background:#4a9eff33;color:var(--color-accent);font-weight:700}.practice-preview-header{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem;margin-bottom:.25rem}.practice-preview-cta{flex-shrink:0}.practice-reps-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.1rem}.practice-reps-step{font-size:.8rem;color:var(--color-text-muted);font-variant-numeric:tabular-nums}.practice-reps-primary-btn{width:100%;justify-content:center;margin-top:.85rem}.practice-reps-secondary{display:flex;justify-content:space-between;margin-top:.55rem}.practice-reps-link{background:none;border:none;cursor:pointer;font-size:.82rem;color:var(--color-text-muted);padding:.2rem 0;transition:color .12s}.practice-reps-link:hover:not(:disabled){color:var(--color-text)}.practice-reps-link:disabled{opacity:.3;cursor:not-allowed}.practice-history-compact{font-size:.83rem;color:var(--color-text-muted);font-family:var(--font-mono);line-height:1.6;margin-top:.55rem;word-break:break-word}@media (max-width: 1023px){.practice-panel-stats{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (min-width: 1181px){.side-col{flex:1 1 280px;min-width:280px;max-width:440px;width:auto}}.ad-col{flex:0 0 160px;width:160px;display:flex;flex-direction:column;align-self:stretch}.ad-placeholder{width:160px;flex:1;min-height:160px;background:#ffffff08;border:1px dashed var(--color-border);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;color:var(--color-text-muted);font-size:.7rem;text-align:center;letter-spacing:.04em;text-transform:uppercase}@media (max-width: 1329px){.ad-col{display:none}}.coming-soon-panel{padding:2rem 1.25rem;text-align:center;color:var(--text-secondary, #9aa0ad)}.coming-soon-panel h3{font-size:1.1rem;font-weight:600;color:var(--text-primary, #e8eaed);margin-bottom:.75rem}.coming-soon-panel p{font-size:.875rem;line-height:1.55;margin-bottom:.5rem}.coming-soon-sub{font-size:.8rem;opacity:.7}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--color-bg: #1a1a2e;--color-surface: #16213e;--color-surface-2: #0f3460;--color-border: #2a3a5e;--color-accent: #4a9eff;--color-accent-hover: #6ab4ff;--color-text: #eaeaea;--color-text-muted: #7a8aaa;--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;--font-mono: "SF Mono", "Fira Code", "Consolas", monospace;--radius: 6px;--layout-nav-width: 180px;--board-vw-offset: 548px;--layout-header-height: 58px}html,body{height:100%;overflow:hidden}body{font-family:var(--font-sans);background:var(--color-bg);color:var(--color-text);line-height:1.6}.app{height:100vh;display:flex;flex-direction:row;overflow:hidden}.app-content{flex:1;min-width:0;display:flex;flex-direction:column;overflow:hidden}.app-shell__backdrop,.app-header{display:none}.app-header{align-items:center;gap:.75rem;min-height:var(--layout-header-height);padding:.75rem 1rem;border-bottom:1px solid var(--color-border);background:var(--color-surface);flex-shrink:0;position:sticky;top:0;z-index:15}.app-header__menu{border:1px solid var(--color-border);background:var(--color-surface-2);color:var(--color-text);border-radius:var(--radius);padding:.4rem .5rem;font-size:1.1rem;font-weight:400;cursor:pointer;transition:border-color .15s,color .15s,background .15s}.app-header__menu:hover{border-color:var(--color-accent);color:var(--color-accent)}.app-header__brand{display:flex;align-items:center;gap:.55rem;min-width:0}.app-header__brand-mark{width:30px;height:30px;flex-shrink:0}.app-header__brand-name{font-size:1rem;font-weight:700;letter-spacing:-.02em;color:var(--color-text)}.app-header__page{margin-left:auto;color:var(--color-text-muted);font-size:.74rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase}html.theme-light{--color-bg: #f0f2f5;--color-surface: #ffffff;--color-surface-2: #e4e8ef;--color-border: #ccd3e0;--color-accent: #3a8eff;--color-accent-hover: #2070dd;--color-text: #1a1a2e;--color-text-muted: #5a6a8a}html.theme-light body{background:var(--color-bg);color:var(--color-text)}@media (max-width: 1023px){.app-shell--compact-nav .app-shell__backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;border:0;padding:0;background:#080c18a8;opacity:0;pointer-events:none;transition:opacity .18s ease;z-index:20}.app-shell--compact-nav.app-shell--nav-open .app-shell__backdrop{opacity:1;pointer-events:auto}.app-shell--compact-nav .nav-sidebar{position:fixed;top:0;left:0;bottom:0;width:min(84vw,220px);max-width:220px;height:100vh;transform:translate(-100%);transition:transform .18s ease;box-shadow:24px 0 48px #00000057;z-index:30}.app-shell--compact-nav.app-shell--nav-open .nav-sidebar{transform:translate(0)}.app-shell--compact-nav .app-header{display:flex}}@media (max-width: 860px){html,body{overflow-x:hidden;overflow-y:auto}.app{height:auto;min-height:100vh;overflow:visible;flex-direction:column}.app-content{min-width:0;max-width:100%}}@media (max-width: 639px){.app-header{padding:.65rem .85rem}.app-header__page{display:none}}.app-shell--nav-collapsed .nav-sidebar{width:48px}.app-shell--nav-collapsed .nav-logo__name,.app-shell--nav-collapsed .nav-item span:not(.nav-icon),.app-shell--nav-collapsed .nav-soon{display:none}.app-shell--nav-collapsed .nav-logo{justify-content:center;padding:.35rem 0;flex-direction:column;gap:.15rem}.app-shell--nav-collapsed .nav-logo__img{width:30px;height:30px}.app-shell--nav-collapsed .nav-item{justify-content:center;padding:.6rem 0;border-left-color:transparent}.app-shell--nav-collapsed .nav-item.active{border-left-color:transparent;background:#4a9eff1a}.nav-divider{height:1px;background:var(--color-border);margin:.3rem .75rem}.app-shell--nav-collapsed .nav-divider{margin:.3rem .4rem}@media (min-width: 1330px){:root{--board-vw-offset: 724px}}
