.cg-wrap{box-sizing:content-box;display:block;position:relative}cg-container{width:100%;height:100%;display:block;position:absolute;top:0}cg-board{-webkit-user-select:none;user-select:none;background-size:cover;width:100%;height:100%;line-height:0;position:absolute;top:0;left:0}cg-board square{pointer-events:none;width:12.5%;height:12.5%;position:absolute;top:0;left:0}cg-board square.move-dest{pointer-events:auto}cg-board square.last-move{will-change:transform}.cg-wrap piece{z-index:2;will-change:transform;pointer-events:none;background-size:cover;width:12.5%;height:12.5%;position:absolute;top:0;left:0}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{pointer-events:none;z-index:2;opacity:.6;width:100%;height:100%;position:relative;top:0;left:0;overflow:hidden}.cg-wrap cg-auto-pieces,.cg-wrap .cg-shapes,.cg-wrap .cg-custom-svgs{pointer-events:none;width:100%;height:100%;position:absolute;top:0;left:0;overflow:visible}.cg-wrap cg-auto-pieces{z-index:2}.cg-wrap cg-auto-pieces piece{opacity:.3}.cg-wrap .cg-shapes{opacity:.6;z-index:2;overflow:hidden}.cg-wrap .cg-custom-svgs{z-index:9}.cg-wrap .cg-custom-svgs svg{overflow:visible}.cg-wrap coords{pointer-events:none;opacity:.8;font-family:sans-serif;font-size:9px;display:flex;position:absolute}.cg-wrap coords.ranks{flex-flow:column-reverse;width:12px;height:100%;top:-20px;left:4px}.cg-wrap coords.ranks.black{flex-flow:column}.cg-wrap coords.ranks.left{align-items:flex-end;left:-15px}.cg-wrap coords.files{text-transform:uppercase;text-align:center;flex-flow:row;width:100%;height:16px;bottom:-4px;left:24px}.cg-wrap coords.files.black{flex-flow:row-reverse}.cg-wrap coords coord{flex:auto}.cg-wrap coords.squares{text-transform:uppercase;text-align:right;flex-flow:column-reverse;width:12.5%;height:100%;bottom:0;left:0}.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.premove-dest{background:radial-gradient(#141e5580 22%,#203085 0,#0000004d 0,#0000 0)}cg-board square.oc.move-dest{background:radial-gradient(#0000 0% 80%,#1455004d 80%)}cg-board square.oc.premove-dest{background:radial-gradient(#0000 0% 80%,#141e5533 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.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);--board-move-dest-fill:radial-gradient(#4e545c99 20%, transparent 21%);--board-capture-dest-shadow:inset 0 0 0 6px #4e545ca6}cg-board square.check{background:radial-gradient(#ff0000b8 0%,#c8000080 30%,#8c000000 80%)!important}cg-board square.last-move{box-shadow:inset 0 0 0 1px #fff4c442;background:#e0c26057!important}cg-board square.selected{box-shadow:inset 0 0 0 2px #fff8cd80;background:#f6d35c94!important}cg-board square.move-dest,cg-board square.move-dest:hover{background:var(--board-move-dest-fill)!important}cg-board square.move-dest.oc{border-radius:50%;box-shadow:var(--board-capture-dest-shadow)!important;background:0 0!important}cg-board square.move-dest.oc:hover{box-shadow:var(--board-capture-dest-shadow)!important;background:0 0!important}.cg-wrap piece.dragging{z-index:110;filter:none;cursor:grabbing}.cg-wrap piece.ghost{opacity:.16;filter:grayscale()brightness(1.5)}.cg-wrap{touch-action:none;width:100%;height:100%;overflow:hidden}.cg-wrap.manipulable cg-board{cursor:default}.cg-wrap.manipulable piece{pointer-events:auto;cursor:default}.cg-wrap.manipulable[data-cursor-color=white] piece.white,.cg-wrap.manipulable[data-cursor-color=black] piece.black{cursor:pointer}.board-drag-target{z-index:5;transform-origin:50%;pointer-events:none;background:#565c6433;border-radius:50%;display:none;position:absolute;transform:scale(1.3);box-shadow:0 3px 8px #2e343c1a}.board-hover-outline{z-index:7;box-sizing:border-box;pointer-events:none;border-radius:3px;position:absolute;box-shadow:inset 0 0 0 4px #b8bfc8f0}.board-drag-move-dest{z-index:8;pointer-events:none;background:var(--board-move-dest-fill);position:absolute}.board-drag-move-dest--occupied{box-shadow:var(--board-capture-dest-shadow);background:0 0;border-radius:50%}.chess-board-container.board-dragging cg-board square.selected{box-shadow:inset 0 0 0 2px #fff8cd70;background:#f6d35c80!important}.chess-board-container.board-dragging cg-board square.move-dest,.chess-board-container.board-dragging cg-board square.move-dest.oc{box-shadow:none!important;background:0 0!important}.chess-board-container.board-dragging .cg-wrap.manipulable cg-board,.chess-board-container.board-dragging .cg-wrap.manipulable piece.dragging{cursor:grabbing}.chess-board-container{cursor:default}coords coord{text-transform:lowercase;font-size:clamp(10px,1.75cqw,14px);font-weight:400;line-height:1}.cg-wrap coords.ranks{left:calc(var(--board-coord-inset) - 2px + max(0px, 2px - .8cqw))}.cg-wrap coords.ranks coord{transform:translateY(24px)}.cg-wrap coords.files{text-align:left;left:0}.cg-wrap coords.files coord{box-sizing:border-box;padding-left:var(--board-coord-inset);transform:translateY(clamp(-4px, calc(var(--board-file-offset) - 2px - max(0px, 3cqw - 21px)), 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),.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-overlay-host{--board-badge-size:clamp(10px, 5%, 44px);--board-badge-font-size:clamp(.3rem, 2.5cqw, 1rem);--board-badge-wide-font-size:clamp(.25rem, 1.8cqw, .8rem);--board-badge-draw-font-size:clamp(.25rem, 1.3cqw, .8rem);--board-badge-inset-x:1px;--board-badge-inset-y:1px}.chess-board-container{--board-coord-inset:.75cqw;--board-file-offset:clamp(2px, .55cqw, 4px);--board-capture-dest-shadow:inset 0 0 0 clamp(2px, .9cqw, 8px) #4e545ca6;aspect-ratio:1;flex-shrink:0;width:100%;display:block;position:relative;overflow:hidden;container-type:inline-size}.board-overlay-host{position:relative}.app-main{flex:1;align-items:stretch;gap:1rem;min-height:0;padding:.75rem 1.5rem;display:flex;overflow:hidden}.board-col{flex-direction:column;flex:none;align-self:flex-start;min-width:0;display:flex}.player-bar{flex-shrink:0;align-items:center;gap:.5rem;height:32px;padding:0 4px;display:flex}.to-move-dot{background:var(--color-border);border-radius:50%;flex-shrink:0;width:10px;height:10px;transition:background .2s}.to-move-dot.active{background:#4ade80}.player-name{color:var(--color-text);font-size:1.1rem;font-weight:500}.player-elo{color:var(--color-text-muted);font-size:.8rem}.player-info-box{box-sizing:border-box;color:#fff;background:#4d4d4d;flex-shrink:0;align-items:center;gap:.6rem;height:44px;padding:.3rem .55rem;display:flex;overflow:hidden}.player-avatar{border-radius:4px;flex-shrink:0;width:36px;height:36px;overflow:hidden}.avatar-image{object-fit:cover;width:100%;height:100%}.avatar-fallback{color:#fff;background:#4a9eff;justify-content:center;align-items:center;width:100%;height:100%;font-size:1rem;font-weight:600;display:flex}.avatar-fallback--neutral{color:#aaa;background:#555;font-size:1.3rem}.player-info-lines{flex-direction:column;flex:1;justify-content:center;align-self:stretch;gap:0;min-width:0;display:flex}.player-line-1{align-items:center;gap:.4rem;min-height:0;display:flex}.player-name{color:#fff;text-overflow:ellipsis;white-space:nowrap;font-size:.92rem;font-weight:700;overflow:hidden}.player-rating{color:#aaa;flex-shrink:0;font-size:.85rem}.player-flag{flex-shrink:0;font-size:1rem}.player-line-2{align-items:center;gap:.3rem;min-height:0;margin-top:-3px;display:flex}.captured-pieces{flex-wrap:nowrap;gap:0;display:flex}.captured-piece-img{vertical-align:middle;flex-shrink:0;width:16px;height:16px;display:inline-block}.material-advantage{color:#aaa;margin-left:2px;font-size:.78rem;font-weight:600}.clock-box{background:#333;border:1px solid #555;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;min-width:64px;height:38px;margin-left:auto;margin-right:-.3rem;padding:0 10px;display:flex}.clock-value{font-family:var(--font-mono,"Courier New", monospace);color:#aaa;font-variant-numeric:tabular-nums;font-size:1.35rem;font-weight:700}.clock-box--active{background:#fff}.clock-box--active .clock-value{color:#1a1a1a}.board-controls{flex-wrap:wrap;flex-shrink:0;justify-content:space-between;align-items:center;gap:.5rem .75rem;width:calc(100% - 24px);max-width:100%;margin-top:.35rem;margin-left:24px;display:flex}.board-controls__nav,.board-controls__actions{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.board-controls__actions{flex:auto}.board-control-btn{letter-spacing:.01em;border-radius:8px;justify-content:center;align-items:center;gap:.35rem;min-height:32px;padding:.42rem .82rem;font-size:.78rem;font-weight:600;display:inline-flex}.board-control-btn--active,.board-btn--active{color:var(--color-accent,#4a9eff);background:#4a9eff26;box-shadow:inset 0 0 0 1px #4a9eff2e;border-color:var(--color-accent,#4a9eff)!important}.board-control-btn--danger,.board-btn--danger{color:#f87171;background:#dc3c3c26;border-color:#dc3c3c80!important}.board-control-btn--danger:hover,.board-btn--danger:hover{background:#dc3c3c47}.board-control-status{border:1px solid var(--color-border);min-height:32px;color:var(--color-text-muted);white-space:nowrap;background:#ffffff0a;border-radius:8px;align-items:center;padding:.42rem .75rem;font-size:.78rem;font-weight:500;display:inline-flex}.nav-btn{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);width:32px;height:32px;color:var(--color-text);cursor:pointer;justify-content:center;align-items:center;font-size:1.1rem;transition:border-color .15s,color .15s;display:flex}.nav-btn:hover:not(:disabled){border-color:var(--color-accent);color:var(--color-accent)}.nav-btn:disabled{opacity:.35;cursor:not-allowed}.move-counter{color:var(--color-text-muted);font-size:.8rem;font-family:var(--font-mono);text-align:center;min-width:56px}.side-col{flex-direction:column;flex:290px;width:min(330px,100%);min-width:270px;max-width:330px;min-height:0;display:flex}.panel-tabs{background:var(--color-bg-secondary,#1e1e1e);border:1px solid var(--color-border);border-radius:10px;flex-shrink:0;align-items:center;gap:.35rem;min-height:36px;padding:4px;display:flex}.panel-tab{border-radius:var(--radius);min-width:0;min-height:36px;color:var(--color-text-muted);text-align:center;cursor:pointer;background:0 0;border:1px solid #0000;flex:1 1 0;padding:.35rem .75rem;font-size:.8rem;font-weight:500;transition:color .15s,background .15s,border-color .15s}.panel-tab:hover:not(:disabled){color:var(--color-text);background:#ffffff0a}.panel-tab.active{color:var(--color-accent);border-color:var(--color-accent,#4a9eff);background:#4a9eff1f;font-weight:600}.panel-tab:disabled{opacity:.3;cursor:not-allowed}.side-panel-wrapper{flex-direction:column;flex:1;min-height:0;display:flex;position:relative}.panel-analyzing-label{color:var(--color-accent);pointer-events:none;z-index:1;white-space:nowrap;font-size:.75rem;font-weight:500;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.panel-content--analyzing{opacity:.35;pointer-events:none}.panel-content{flex-direction:column;flex:1;gap:.5rem;min-height:0;padding-top:.5rem;display:flex;overflow-y:auto}.move-list{min-height:0;max-height:none;font-family:var(--font-mono);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text);flex:1;padding:.5rem;font-size:.875rem;overflow-y:auto}.move-full-row{display:block}.move-pair-row{align-items:center;gap:2px;min-height:24px;padding:1px 0;display:flex}.move-number{color:var(--color-text-muted);text-align:right;-webkit-user-select:none;user-select:none;flex-shrink:0;min-width:28px;margin-right:2px;font-size:.8rem}.move-cell{flex-shrink:0;align-items:center;gap:2px;display:inline-flex}.move-san{cursor:pointer;white-space:nowrap;border-radius:3px;min-width:66px;padding:2px 6px;transition:background .1s,color .1s;display:inline-block}.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;text-align:right;-webkit-user-select:none;user-select:none;white-space:nowrap;flex-shrink:0;width:6ch;padding:0 5px}.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{margin-top:1px;margin-bottom:2px;display:block}.variation-block{border-left:2px solid var(--color-border);color:var(--color-text-muted);margin:2px 0 2px 8px;padding:2px 4px 2px 8px;font-size:.82rem;display:block}.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;color:var(--color-text-muted);border-top:1px solid var(--color-border);margin-top:.5rem;padding:.25rem;font-size:.8rem}.import-panel{flex-direction:column;gap:.75rem;display:flex}.import-label{text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);font-size:.75rem;font-weight:600}.import-textarea{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text);font-size:.75rem;font-family:var(--font-mono);resize:vertical;outline:none;width:100%;padding:.5rem;line-height:1.5}.import-textarea:focus{border-color:var(--color-accent)}.import-error{color:#f87171;font-size:.8rem}.fen-row{gap:.5rem;display:flex}.fen-input{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text);font-size:.75rem;font-family:var(--font-mono);outline:none;flex:1;min-width:0;padding:.4rem .6rem}.fen-input:focus{border-color:var(--color-accent)}.btn{border-radius:var(--radius);cursor:pointer;white-space:nowrap;border:none;padding:.4rem .9rem;font-size:.8rem;font-weight:500;transition:background .15s,opacity .15s}.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{border-bottom:1px solid var(--color-border);cursor:pointer;justify-content:space-between;align-items:center;gap:.3rem;padding:.4rem .6rem;transition:background .15s;display:flex}.nav-logo:hover{background:#ffffff0a}.nav-logo__img{flex-shrink:0;width:32px;height:32px}.nav-logo__name{letter-spacing:-.02em;color:var(--color-text);flex:1;font-size:1.1rem;font-weight:700}.nav-logo-toggle{color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;padding:.2rem .3rem;transition:color .15s;display:flex}.nav-logo-toggle:hover{color:var(--color-text);background:#ffffff14}.nav-sidebar{width:var(--layout-nav-width);border-right:1px solid var(--color-border);background:var(--color-surface);flex-direction:column;flex-shrink:0;padding:.25rem 0;transition:width .2s;display:flex}.nav-item{color:var(--color-text-muted);cursor:pointer;-webkit-user-select:none;user-select:none;border-left:3px solid #0000;align-items:center;gap:.75rem;padding:.6rem 1rem;font-size:.875rem;transition:color .15s,border-color .15s,background .15s;display:flex}.nav-item:hover{color:var(--color-text)}.nav-item.active{color:var(--color-accent);border-left-color:var(--color-accent);background:#4a9eff0f}.nav-icon{text-align:center;flex-shrink:0;justify-content:center;align-items:center;width:1.2rem;font-size:1rem;display:inline-flex}.nav-icon svg{width:1rem;height:1rem}.nav-soon{background:var(--color-surface-2);color:var(--color-text-muted);border-radius:3px;margin-left:auto;padding:0 4px;font-size:.65rem}.board-with-eval{align-items:stretch;gap:8px;width:fit-content;min-width:0;max-width:100%;display:flex}.board-and-players{min-width:0;max-width:100%;width:min(880px, calc(100dvh - 164px), calc(100vw - var(--board-vw-offset)));box-sizing:border-box;background:#4d4d4d;border:1px solid #505050;flex-direction:column;flex-shrink:0;display:flex;overflow:hidden}.player-info-box{width:100%}.eval-bar-container{border-radius:var(--radius);border:1px solid var(--color-border);flex-shrink:0;width:16px;position:relative;overflow:visible}.eval-bar-inner{border-radius:var(--radius);position:absolute;inset:0;overflow:hidden}.eval-bar-segment{transition:height .2s ease-out,background;position:absolute;left:0;right:0}.eval-bar-top{top:0}.eval-bar-bot{bottom:0}.eval-bar-midline{pointer-events:none;z-index:5;background:#8080808c;width:100%;height:1px;position:absolute;top:50%;left:0}.eval-bar-label{font-size:.6rem;font-weight:700;font-family:var(--font-mono);color:#e2e8f0;pointer-events:none;white-space:nowrap;z-index:10;border:1px solid var(--color-border);background:#0f1220d9;border-radius:3px;padding:2px 4px;line-height:1;position:absolute;left:50%;transform:translate(-50%)translateY(-50%)}@media (width<=480px){.eval-bar-label{border-radius:2px;padding:1px 2px;font-size:.46rem}}.eval-bar-container:has(.eval-bar-analyzing){border-color:var(--color-accent);animation:1.5s ease-in-out infinite eval-pulse}.eval-bar-analyzing{display:none}@keyframes eval-pulse{0%,to{border-color:var(--color-border)}50%{border-color:var(--color-accent)}}.stub-page{color:var(--color-text-muted);flex:1;justify-content:center;align-items:center;font-size:1rem;display:flex}@media (width<=1180px){.app-main{flex-direction:column;align-items:stretch;padding:1rem;overflow-y:auto}.board-col{width:100%;max-width:100%}.board-with-eval{gap:6px;width:100%}.board-and-players{flex:auto;width:100%}.chess-board-container{aspect-ratio:1;max-width:100%;width:100%!important;height:auto!important}.side-col{flex:auto;width:100%;min-width:0;max-width:100%;min-height:360px}.board-controls{flex-wrap:wrap;width:calc(100% - 22px);margin-left:22px;padding-left:0}.board-controls__nav,.board-controls__actions{width:100%}.board-controls__nav{justify-content:center}.board-controls__actions{grid-template-columns:repeat(3,minmax(0,1fr));gap:.35rem;display:grid}.board-controls__actions .board-control-btn{width:100%}.panel-tabs{flex-wrap:nowrap;height:auto}.panel-tab{flex:1 1 0}}@media (width<=860px){.app-main{gap:.75rem;padding:.75rem}.eval-bar-container{width:12px}.board-controls{width:calc(100% - 18px);margin-left: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 (width<=480px){.app-main{gap:.5rem;padding:.5rem .4rem}.board-col{max-width:100%}.board-with-eval{gap:3px}.eval-bar-container{width:8px}.board-controls{justify-content:flex-start;gap:.35rem;width:calc(100% - 11px);margin-left:11px}.board-controls__nav,.board-controls__actions{width:100%}.board-controls__nav{justify-content:center}.board-controls__actions{grid-template-columns:repeat(3,minmax(0,1fr));gap:.35rem;display:grid}.board-controls__actions .board-control-btn{width:100%}.board-and-players{width:100%;margin:0}.board-controls .btn,.board-control-status{padding:.3rem .5rem;font-size:.72rem}.board-control-btn{min-height:30px}.nav-btn{width:40px;height:40px;font-size:1.3rem}.move-counter{min-width:0;font-size:.75rem}.panel-tab,.import-tab{min-width:0;font-size:.74rem}.import-tabs{grid-template-columns:repeat(3,minmax(0,1fr));display:grid}.player-info-box{gap:.4rem;height:36px;padding:2px 6px}.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}.chess-board-container,.board-overlay-host{--board-badge-size:clamp(18px, 5.8%, 22px);--board-badge-font-size:clamp(.42rem, .98rem, .56rem);--board-badge-wide-font-size:clamp(.35rem, .84rem, .46rem);--board-badge-draw-font-size:clamp(.36rem, .88rem, .48rem);--board-badge-inset-x:1px;--board-badge-inset-y:1px}.board-result-badge--draw{font-size:var(--board-badge-draw-font-size)}.board-drag-target{display:none}}@media (pointer:coarse){.board-hover-outline{display:none}.board-drag-target{background:#444a525c;display:block;transform:scale(1.64);box-shadow:0 4px 12px #1c20261a}.cg-wrap piece.dragging{width:16.5%;height:16.5%;translate:-12% -56%}}.side-panel-content{flex-direction:column;flex:1;gap:.5rem;min-height:0;padding:.5rem 0;display:flex;overflow:hidden}.panel-empty{color:var(--color-text-muted);flex:1;justify-content:center;align-items:center;font-size:.85rem;display:flex}.analyzing-bar{border-radius:var(--radius);background:#4a9eff0f;border:1px solid #4a9eff33;flex-shrink:0;align-items:center;gap:.4rem;padding:.3rem .5rem;display:flex;position:relative;overflow:hidden}.analyzing-bar__fill{pointer-events:none;background:#4a9eff47;transition:width .4s;position:absolute;top:0;bottom:0;left:0}.analyzing-dot{background:var(--color-accent);border-radius:50%;flex-shrink:0;width:6px;height:6px;animation:1.2s ease-in-out infinite analyzing-pulse}@keyframes analyzing-pulse{0%,to{opacity:1}50%{opacity:.3}}.analyzing-text{color:var(--color-accent);font-size:.75rem;font-family:var(--font-mono)}.eval-display{flex-shrink:0;align-items:baseline;gap:.5rem;padding:.35rem .5rem;display:flex}.eval-display-value{font-family:var(--font-mono);color:var(--color-text);font-size:1rem;font-weight:600}.eval-display-depth{color:var(--color-text-muted);font-size:.7rem;font-family:var(--font-mono)}.eval-graph-wrap{flex-direction:column;flex-shrink:0;gap:1px;display:flex;position:relative}.eval-graph-container{border-radius:var(--radius);border:1px solid var(--color-border);cursor:crosshair;background:#0f1117;flex-grow:0;flex-shrink:0;height:120px;overflow:hidden}.eval-graph-svg{flex-shrink:0;width:100%;height:120px;min-height:120px;max-height:120px;display:block}.eval-graph-empty{cursor:default;justify-content:center;align-items:center;height:120px;display:flex}.eval-graph-waiting{color:var(--color-text-muted);font-size:.75rem}.move-grade{-webkit-user-select:none;user-select:none;color:#fff;letter-spacing:-.03em;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:18px;height:18px;padding:0;font-family:system-ui,-apple-system,sans-serif;font-size:.7rem;font-weight:900;line-height:1;display:inline-flex}.move-grade__icon{width:.78rem;height:.78rem;display:block}.grade-brilliant,.grade-blunder,.grade-inaccuracy{font-size:.55rem}.grade-placeholder{flex-shrink:0;width:18px;height:18px;display:inline-block}.grade-brilliant{background:#93c5fd}.grade-great{background:#3b82f6}.grade-best{background:#22c55e}.grade-excellent{background:#4ade80}.grade-good{background:#86efac}.grade-forced{background:#6b7280}.grade-inaccuracy{color:#1a1a1a;background:#facc15}.grade-mistake{background:#fb923c}.grade-blunder{background:#ef4444}.grade-miss{background:#a78bfa}.grade-pending{background:#374151;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:18px;height:18px;display:inline-flex;position:relative}.grade-pending:after{content:"";border:1.5px solid #0000;border-top-color:#9ca3af;border-radius:50%;animation:.7s linear infinite grade-spin;position:absolute;inset:3px}@keyframes grade-spin{to{transform:rotate(360deg)}}.board-grade-badge{z-index:10;width:var(--board-badge-size);height:var(--board-badge-size);color:#fff;font-family:system-ui,-apple-system,sans-serif;font-weight:900;font-size:var(--board-badge-font-size);pointer-events:none;letter-spacing:-.03em;border-radius:50%;justify-content:center;align-items:center;line-height:1;display:flex;position:absolute;transform:translate(-100%);box-shadow:inset 0 0 0 2px #ffffff59}.board-grade-badge[data-grade=brilliant],.board-grade-badge[data-grade=blunder],.board-grade-badge[data-grade=inaccuracy]{font-size:var(--board-badge-wide-font-size)}.board-grade-badge__icon{width:62%;height:62%;display:block}.board-grade-badge-pending{z-index:10;width:var(--board-badge-size);height:var(--board-badge-size);pointer-events:none;background:#1e1e1ebf;border-radius:50%;position:absolute;transform:translate(-100%);box-shadow:inset 0 0 0 2px #ffffff26}.board-grade-badge-pending:after{content:"";border:2px solid #0000;border-top-color:#ffffffb3;border-radius:50%;animation:.7s linear infinite grade-spin;position:absolute;inset:20%}.board-result-badge{z-index:11;width:var(--board-badge-size);height:var(--board-badge-size);color:#fff;font-family:system-ui,-apple-system,sans-serif;font-weight:900;font-size:var(--board-badge-font-size);pointer-events:none;border-radius:50%;justify-content:center;align-items:center;line-height:1;display:flex;position:absolute;transform:translate(-100%);box-shadow:inset 0 0 0 2px #ffffff59,0 2px 8px #0000008c}.board-result-badge--checkmate{background:#111}.board-result-badge--draw{font-size:var(--board-badge-draw-font-size);background:#6b7280}.move-pair{align-items:center;gap:.2rem;padding:1px 0;display:flex}.move-placeholder{flex:1}.parse-error{color:#f87171;text-align:center;padding:0 .5rem;font-size:.8rem}.analyzing-bar--error{background:#f8717114;border-color:#f8717140}.analyzing-bar--error .analyzing-text{color:#f87171}.best-lines{flex-direction:column;flex-shrink:0;gap:2px;height:66px;display:flex;overflow:hidden}.best-line-row{box-sizing:border-box;cursor:pointer;text-align:left;width:100%;height:32px;color:var(--color-text);background:#ffffff0a;border:1px solid #ffffff0f;border-radius:5px;align-items:center;gap:.5rem;padding:.35rem .5rem;font-size:.82rem;transition:background .12s,opacity .15s;display:flex}.best-line-row:hover{background:#ffffff17;border-color:#ffffff26}.best-line-dot{border-radius:50%;flex-shrink:0;width:9px;height:9px}.best-line-move{font-weight:600;font-family:var(--font-mono,monospace);min-width:2.8rem;color:var(--color-text)}.best-line-eval{font-variant-numeric:tabular-nums;color:var(--color-text-muted);margin-left:auto;font-size:.78rem}.best-line-skeleton{cursor:default;background:linear-gradient(90deg,#ffffff0a 25%,#ffffff14 50%,#ffffff0a 75%) 0 0/200% 100%;height:32px;animation:1.4s infinite skeleton-shimmer}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.best-line-spacer{visibility:hidden;pointer-events:none}.best-lines-section{flex-direction:column;gap:4px;margin-bottom:.25rem;display:flex}.lines-toggle-btn{border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text-muted);cursor:pointer;background:#ffffff0d;align-self:flex-start;padding:.25rem .65rem;font-size:.75rem;font-weight:500;transition:background .12s,border-color .12s,color .12s}.lines-toggle-btn:hover{border-color:var(--color-accent);color:var(--color-text);background:#ffffff17}.lines-toggle-btn.active{color:#4ade80;background:#4ade801a;border-color:#4ade8059}.eval-graph-tooltip{pointer-events:none;z-index:10;border:1px solid var(--color-border);white-space:nowrap;background:#0c0e14f2;border-radius:5px;flex-direction:column;align-items:center;gap:1px;padding:4px 8px;display:flex;position:absolute;bottom:calc(100% + 4px);transform:translate(-50%);box-shadow:0 2px 8px #00000080}.eval-graph-tooltip-move{color:var(--color-text);font-size:.72rem;font-weight:600;font-family:var(--font-mono,monospace)}.eval-graph-tooltip-eval{color:var(--color-text-muted);font-variant-numeric:tabular-nums;font-size:.68rem}.eval-graph-tooltip-grade{text-transform:uppercase;letter-spacing:.04em;font-size:.68rem;font-weight:700}.game-report{border:1px solid var(--color-border);border-radius:var(--radius);background:#0f1117d9;flex-direction:row;flex-shrink:0;gap:1px;display:flex;overflow:hidden}.game-report-side{flex-direction:column;flex:1;gap:4px;padding:10px 12px;display:flex}.game-report-side--user{background:#4ade800a}.game-report-divider{background:var(--color-border);flex-shrink:0;width:1px}.game-report-header{justify-content:space-between;align-items:baseline;gap:6px;display:flex}.game-report-label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.06em;font-size:.7rem;font-weight:500}.game-report-accuracy{font-variant-numeric:tabular-nums;font-size:1.15rem;font-weight:700;line-height:1}.game-report-acpl{color:var(--color-text-muted);margin-top:1px;font-size:.65rem}.game-report-acpl strong{color:var(--color-text);font-weight:600}.game-report-grades{flex-wrap:wrap;gap:4px;margin-top:3px;display:flex}.game-report-pill{border-radius:4px;align-items:center;gap:2px;padding:2px 6px;font-family:system-ui,sans-serif;font-size:.62rem;font-weight:600;line-height:1.3;display:inline-flex}.game-report-pill-sym{opacity:.85}.game-report-pill__icon{width:.72rem;height:.72rem;display:block}.game-report-pill-count{font-variant-numeric:tabular-nums}.gr-brilliant{color:#22d3ee;background:#22d3ee38}.gr-great{color:#22c55e;background:#22c55e38}.gr-best{color:#4ade80;background:#22c55e2e}.gr-excellent{color:#86efac;background:#4ade8026}.gr-good{color:#86efac;background:#86efac1f}.gr-inaccuracy{color:#eab308;background:#eab30838}.gr-mistake{color:#fb923c;background:#f9731638}.gr-blunder{color:#ef4444;background:#ef444438}.gr-miss{color:#a78bfa;background:#a78bfa38}.load-panel{flex-direction:column;gap:.6rem;height:100%;display:flex}.import-tabs{background:var(--color-surface);border-radius:var(--radius);flex-shrink:0;gap:2px;padding:2px;display:flex}.import-tab{border-radius:calc(var(--radius) - 2px);color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;flex:1;padding:.3rem .4rem;font-size:.78rem;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{flex-direction:column;flex-shrink:0;gap:.4rem;display:flex}.account-link-row{align-items:center;gap:.4rem;display:flex}.account-link-input{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);min-width:0;color:var(--color-text);outline:none;flex:1;padding:.35rem .5rem;font-size:.82rem}.account-link-input:focus{border-color:var(--color-accent)}.account-link-input:disabled{opacity:.5}.game-list{flex-direction:column;flex:1;gap:1px;min-height:0;display:flex;overflow-y:auto}.game-list-empty{color:var(--color-text-muted);padding:.5rem 0;font-size:.82rem}.game-row{border-radius:var(--radius);color:var(--color-text);cursor:pointer;text-align:left;background:0 0;border:none;flex-direction:column;gap:.4rem;width:100%;padding:.4rem .5rem;font-size:.8rem;transition:background .12s;display:flex}.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{align-items:center;gap:5px;min-width:0;display:flex}.game-row__color-dot{border:1px solid var(--border);border-radius:50%;flex-shrink:0;width:10px;height:10px;display:inline-block}.game-row__color-dot[data-color=white]{background:#fff}.game-row__color-dot[data-color=black]{background:#333}.game-row__players{flex:1;align-items:center;gap:5px;min-width:0;display:flex;overflow:hidden}.game-row__username,.game-row__opponent{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.game-row__vs{color:var(--color-text-muted);flex-shrink:0;font-size:.7rem}.game-row__result{text-align:center;border-radius:3px;flex-shrink:0;width:1.4rem;margin-left:auto;padding:.1rem .2rem;font-size:.75rem;font-weight:600}.game-row__result--w{color:#4ade80}.game-row__result--l{color:#f87171}.game-row__result--d{color:var(--color-text-muted)}.game-row__line2{color:var(--color-text-muted);align-items:center;gap:1px;padding-left:1px;font-size:.72rem;display:flex}.game-row__line2-sep{opacity:.5;margin:0 .35rem}.game-row__meta{color:var(--color-text-muted);flex-shrink:0;font-size:.72rem}.game-list__load-more{border:1px solid var(--color-border,#383838);color:var(--color-text-muted);cursor:pointer;white-space:nowrap;background:0 0;border-radius:4px;padding:2px 8px;font-size:.72rem;transition:color .15s,border-color .15s,background .12s}.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);text-align:center;opacity:.6;padding:.3rem 0;font-size:.72rem}.game-list-controls{flex-direction:column;flex-shrink:0;gap:.3rem;margin-top:-.3rem;display:flex}.game-list-header{flex-shrink:0;align-items:center;gap:.5rem;padding:0 .1rem;display:flex}.game-list-count{color:var(--color-text-muted);flex:1;font-size:.75rem}.game-list-loading-status{color:var(--color-text-muted,#666);font-size:.72rem}.game-list__cancel-btn{color:var(--color-text-muted,#666);border:1px solid var(--color-border,#383838);cursor:pointer;white-space:nowrap;background:0 0;border-radius:4px;padding:2px 8px;font-size:.72rem;transition:color .12s,border-color .12s}.game-list__cancel-btn:hover{color:var(--color-text,#bbb);border-color:var(--color-text-muted,#555)}.game-filter-bar{flex-direction:column;flex-shrink:0;gap:.35rem;padding:0 .1rem;display:flex}.game-opponent-row{align-items:center;gap:.3rem;display:flex}.game-opponent-search{background:var(--color-bg-secondary,#222);min-width:0;color:var(--color-text,#ccc);border:1px solid var(--color-border,#383838);box-sizing:border-box;border-radius:5px;outline:none;flex:1;padding:4px 8px;font-size:.78rem;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{white-space:nowrap;font-size:.72rem;padding:3px 8px!important}.game-opponent-search-btn{background:var(--color-accent,#4a9eff)!important;color:#fff!important;border:none!important}.game-opponent-clear-btn{color:var(--color-text-muted,#666)!important;border:1px solid var(--color-border,#383838)!important;background:0 0!important}.game-opponent-clear-btn:hover{color:var(--color-text,#bbb)!important}.game-opponent-hint{color:var(--color-text-muted,#666);padding:0 .1rem;font-size:.72rem}.game-opponent-hint-link{color:var(--color-accent,#4a9eff);font-size:inherit;cursor:pointer;background:0 0;border:none;padding:0;text-decoration:underline}.game-filter-row{flex-wrap:wrap;align-items:center;gap:.4rem;display:flex}.game-filter-group{background:var(--color-bg-secondary,#1e1e1e);border:1px solid var(--color-border,#383838);border-radius:5px;gap:2px;padding:2px;display:flex}.game-filter-btn{color:var(--color-text-muted,#666);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:3px;padding:2px 7px;font-size:.72rem;line-height:1.5;transition:background .12s,color .12s}.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{appearance:none;background:var(--color-bg-secondary,#1e1e1e) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%23888'/%3E%3C/svg%3E") no-repeat right 6px center;color:var(--color-text-muted,#888);border:1px solid var(--color-border,#383838);cursor:pointer;background-size:8px 5px;border-radius:5px;outline:none;margin-left:auto;padding:3px 20px 3px 5px;font-size:.72rem;transition:border-color .15s}.game-sort-select:focus{border-color:var(--color-accent,#4a9eff)}@media (width<=480px){.game-filter-row{gap:.25rem}.game-filter-group{gap:1px;padding:1px}.game-filter-btn{padding:2px 5px;font-size:.68rem}.game-sort-select{font-size:.72rem}}.game-list__load-actions{gap:.4rem;margin-top:.25rem;display:flex}.game-list__load-all{color:var(--color-text-muted,#666);border:1px solid var(--color-border,#383838);cursor:pointer;background:0 0;border-radius:5px;flex:1;padding:6px 0;font-size:.78rem;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{z-index:100;background:#00000040;position:absolute;inset:0}.promotion-picker{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border-radius:6px;width:12.5%;display:flex;position:absolute;overflow:hidden;box-shadow:0 6px 28px #0000008c,0 0 0 1px #ffffff14}.promotion-cancel{aspect-ratio:1;cursor:pointer;color:#ccc;background:#505050e6;border:none;flex-shrink:0;justify-content:center;align-items:center;width:100%;font-size:.9rem;transition:background .12s;display:flex}.promotion-cancel:hover{color:#fff;background:#646464f2}.promotion-choice{aspect-ratio:1;cursor:pointer;background:#f5f5f0f2;border:none;border-bottom:1px solid #00000014;flex-shrink:0;justify-content:center;align-items:center;width:100%;transition:background .12s;display:flex}.promotion-choice:hover{background:#dcebfff2}.promotion-choice:last-child{border-bottom:none}.game-row__analyzed-badge{color:#4caf50;flex-shrink:0;margin-right:4px;font-size:.75rem;font-weight:700}.game-row--cached{opacity:.88}.identity-prompt{color:#999;align-items:center;gap:8px;margin-top:6px;font-size:.78rem;display:flex}.identity-prompt__text{flex:1}.identity-prompt__yes{color:#fff;cursor:pointer;background:#4a7fa5;border:none;border-radius:4px;padding:2px 10px;font-size:.75rem}.identity-prompt__yes:hover{background:#5a9abf}.identity-prompt__no{color:#888;cursor:pointer;background:0 0;border:1px solid #555;border-radius:4px;padding:2px 10px;font-size:.75rem}.identity-prompt__no:hover{color:#bbb;border-color:#888}.account-link-input-wrap{flex:1;min-width:0;position:relative}.account-link-input-wrap .account-link-input{box-sizing:border-box;width:100%}.account-link-input-wrap--crowned .account-link-input{padding-right:1.6rem}.identity-crown{color:#c8a550bf;pointer-events:none;-webkit-user-select:none;user-select:none;font-size:1.1rem;font-weight:700;line-height:1;position:absolute;top:50%;right:.45rem;transform:translateY(-61%)}.username-suggestions{background:var(--color-bg-panel,#1e1e1e);border:1px solid var(--color-border);border-radius:0 0 var(--radius) var(--radius);z-index:100;border-top:none;margin:0;padding:0;list-style:none;position:absolute;top:100%;left:0;right:0;overflow:hidden}.username-suggestions__item{color:var(--color-text);cursor:pointer;align-items:center;padding:.3rem .5rem;font-size:.82rem;display:flex}.username-suggestions__crown{color:#c8a550cc;margin-left:.3rem;font-size:1.1rem;font-weight:700;line-height:1;position:relative;top:-.15em}.username-suggestions__item:hover{background:var(--color-border)}.auth-overlay{z-index:1000;background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.auth-modal{background:#1a1b23;border:1px solid #ffffff1a;border-radius:12px;width:380px;max-width:90vw;padding:2rem;position:relative;box-shadow:0 16px 48px #00000080}.auth-close{color:#ffffff80;cursor:pointer;background:0 0;border:none;padding:.25rem;font-size:1.5rem;line-height:1;position:absolute;top:.75rem;right:.75rem}.auth-close:hover{color:#fff}.auth-tabs{border-bottom:1px solid #ffffff1a;gap:1px;margin-bottom:1.5rem;display:flex}.auth-tab{color:#ffffff80;cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;padding:.5rem 0;font-size:.9rem;transition:color .15s,border-color .15s}.auth-tab.active{color:#fff;border-bottom-color:#7c3aed}.auth-form{flex-direction:column;gap:.75rem;display:flex}.auth-input-wrap{align-items:center;display:flex;position:relative}.auth-input-wrap .auth-input{width:100%;padding-right:2.5rem}.auth-eye{cursor:pointer;opacity:.6;-webkit-user-select:none;user-select:none;background:0 0;border:none;padding:0;font-size:1rem;line-height:1;transition:opacity .15s;position:absolute;top:50%;right:.5rem;transform:translateY(-50%)}.auth-eye:hover{opacity:1}.auth-input{color:#fff;background:#ffffff0f;border:1px solid #ffffff1f;border-radius:6px;outline:none;padding:.6rem .75rem;font-size:.9rem}.auth-input:focus{border-color:#7c3aed}.auth-error{color:#e55;padding:.25rem 0;font-size:.8rem}.auth-requirements{flex-direction:column;gap:.25rem;margin-top:-.25rem;display:flex}.auth-req-row{align-items:center;gap:.4rem;font-size:.78rem;transition:color .15s;display:flex}.auth-req-unmet{color:#ffffff59}.auth-req-met{color:#4ade80}.auth-submit{color:#fff;cursor:pointer;background:#7c3aed;border:none;border-radius:6px;padding:.6rem;font-size:.9rem;font-weight:600;transition:opacity .15s}.auth-submit:hover{opacity:.9}.auth-submit:disabled{opacity:.6;cursor:not-allowed}.auth-divider{color:#fff6;align-items:center;gap:1rem;margin:1.25rem 0;font-size:.8rem;display:flex}.auth-divider:before,.auth-divider:after{content:"";background:#ffffff1a;flex:1;height:1px}.auth-oauth{flex-direction:column;gap:.5rem;display:flex}.auth-oauth-btn{color:#fff;text-align:center;cursor:pointer;background:#ffffff0f;border:1px solid #ffffff1a;border-radius:6px;padding:.5rem .75rem;font-size:.85rem;text-decoration:none;transition:background .15s;display:block}.auth-oauth-btn:hover{background:#ffffff1f}.nav-spacer{flex:1}.nav-user{border-top:1px solid var(--border);padding:.5rem .75rem}.nav-user--collapsed{justify-content:center;padding:.4rem 0;display:flex}.nav-user-icon-btn{color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:.3rem;font-size:1.2rem;line-height:1;transition:color .15s,background .15s}.nav-user-icon-btn:hover{color:var(--color-text);background:#ffffff14}.nav-user--collapsed .nav-user-btn{justify-content:center;width:auto;padding:.25rem}.nav-signin-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:6px;width:100%;padding:.5rem;font-size:.85rem;transition:opacity .15s}.nav-signin-btn:hover{opacity:.9}.nav-user-btn{width:100%;color:var(--text-primary);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:6px;align-items:center;gap:.5rem;padding:.35rem .4rem;font-size:.8rem;transition:background .15s;display:flex}.nav-user-btn:hover{background:#ffffff0f}.nav-user-btn.active{background:#ffffff1a}.nav-user-avatar-wrap{flex-shrink:0;position:relative}.nav-user-avatar{background:var(--accent);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:.75rem;font-weight:600;display:flex}.nav-user-avatar--img{object-fit:cover;background:var(--accent);border-radius:50%;width:28px;height:28px}.nav-user-admin-badge{pointer-events:none;font-size:.6rem;line-height:1;position:absolute;bottom:-4px;right:-4px}.nav-user-name{text-overflow:ellipsis;white-space:nowrap;flex:1 1 0;min-width:0;overflow:hidden}.nav-user-logout:hover{color:#e55;border-color:#e55}.nav-sync-msg{color:var(--accent);text-align:center;padding:.25rem 0;font-size:.75rem}[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;max-width:640px;padding:2rem;overflow-y:auto}.profile-title{color:var(--color-text);margin-bottom:1.5rem;font-size:1.4rem;font-weight:700}.profile-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);margin-bottom:1rem;padding:1.25rem 1.5rem}.profile-section-title{color:var(--color-text);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.75rem;font-size:.9rem;font-weight:600}.profile-section-desc{color:var(--color-text-muted);margin-bottom:.75rem;font-size:.82rem}.profile-info-grid{flex-direction:column;gap:.4rem;display:flex}.profile-info-row{gap:1rem;font-size:.875rem;display:flex}.profile-info-label{color:var(--color-text-muted);flex-shrink:0;min-width:100px}.profile-info-value{color:var(--color-text);font-weight:500}.profile-guest-note{color:var(--color-text-muted);font-size:.85rem;font-style:italic}.profile-field-group{flex-direction:column;gap:.85rem;display:flex}.profile-field{flex-direction:column;gap:.35rem;display:flex}.profile-field-label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:.78rem;font-weight:500}.profile-input{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text);outline:none;width:100%;max-width:320px;padding:.45rem .65rem;font-size:.875rem}.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{align-items:center;gap:.75rem;display:flex}.profile-msg{font-size:.8rem;font-weight:500}.profile-msg--ok{color:#4ade80}.profile-msg--err{color:#f87171}.profile-help-text{color:var(--color-text-muted);margin-top:.15rem;font-size:.75rem}.profile-toggle-group{border:1px solid var(--color-border);border-radius:var(--radius);gap:1px;width:fit-content;display:flex;overflow:hidden}.profile-toggle-btn{color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;padding:.35rem 1rem;font-size:.82rem;font-weight:500;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{flex-wrap:wrap;gap:.6rem;display:flex}.profile-board-swatch{border:2px solid var(--color-border);border-radius:var(--radius);cursor:pointer;background:0 0;flex-direction:column;align-items:center;gap:.3rem;width:60px;padding:.3rem;transition:border-color .15s;display:flex}.profile-board-swatch:hover{border-color:var(--color-text-muted)}.profile-board-swatch.active{border-color:var(--color-accent)}.swatch-half{width:40px;height:16px;display:block}.swatch-light{border-radius:3px 3px 0 0}.swatch-dark{border-radius:0 0 3px 3px}.swatch-label{color:var(--color-text-muted);white-space:nowrap;font-size:.65rem}.coach-panel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);flex-direction:column;flex-shrink:0;margin-bottom:.5rem;display:flex;overflow:hidden}.coach-panel--empty{text-align:center;padding:1rem}.coach-panel__empty-msg{color:var(--color-text-muted);font-size:.82rem}.coach-panel__nav{border-bottom:1px solid var(--color-border);background:#4a9eff0d;flex-shrink:0;align-items:center;gap:.5rem;padding:.4rem .6rem;display:flex}.coach-panel__nav-btn{border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text-muted);cursor:pointer;background:0 0;padding:.15rem .45rem;font-size:.85rem;line-height:1;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{text-align:center;color:var(--color-accent);letter-spacing:.02em;text-transform:uppercase;flex:1;font-size:.75rem;font-weight:600}.coach-panel__content{max-height:400px;padding:.75rem;overflow-y:auto}.coach-panel__loading{color:var(--color-text-muted);flex-direction:column;align-items:center;gap:.5rem;padding:1rem;font-size:.82rem;display:flex}.coach-panel__spinner{border:2px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;flex-shrink:0;width:18px;height:18px;animation:.7s linear infinite coach-spin;display:inline-block}@keyframes coach-spin{to{transform:rotate(360deg)}}.coach-panel__error{border-radius:var(--radius);color:#ff8080;background:#ff505014;border:1px solid #ff505040;padding:.6rem;font-size:.8rem}.coach-panel__no-lesson-msg{color:var(--color-text-muted);text-align:center;padding:.5rem 0;font-size:.82rem;font-style:italic}.coach-panel__checklist{background:#ffb43214;border:1px solid #ffb43240;border-radius:6px;margin-bottom:.5rem;padding:.6rem .75rem}.coach-panel__checklist-label{color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.03em;margin:0 0 .35rem;font-size:.78rem;font-weight:600}.coach-panel__checklist-questions{color:var(--color-text);margin:0;padding-left:1.2rem;font-size:.82rem;line-height:1.6}.coach-panel__checklist-questions li{margin-bottom:.15rem}.lesson-card{flex-direction:column;gap:.6rem;display:flex}.lesson-card__header{border-bottom:1px solid var(--color-border);flex-wrap:wrap;align-items:center;gap:.5rem;padding-bottom:.5rem;display:flex}.lesson-card__move{background:var(--color-surface-2);color:var(--color-text-muted);border-radius:var(--radius);letter-spacing:.03em;text-transform:uppercase;padding:.15rem .45rem;font-size:.72rem;font-weight:700}.lesson-card__principle{letter-spacing:.02em;text-transform:uppercase;border:1px solid;border-radius:999px;padding:.16rem .5rem;font-size:.72rem;font-weight:700}.lesson-card__confidence{color:var(--color-accent);opacity:.7;letter-spacing:.05em;font-size:.7rem}.lesson-card__body{flex-direction:column;gap:.4rem;display:flex}.lesson-card__para{color:var(--color-text);margin:0;font-size:.83rem;line-height:1.55}.lesson-card__para:last-child{margin-bottom:0}.lesson-card__steps{flex-direction:column;gap:.55rem;display:flex}.lesson-card__step{align-items:flex-start;gap:.5rem;line-height:1.45;display:flex}.lesson-card__step-icon{text-align:center;flex-shrink:0;width:1.4rem;margin-top:.05rem;font-size:.95rem}.lesson-card__step-text{color:var(--color-text);flex:1;font-size:.83rem}.socratic-prompt{flex-direction:column;gap:.65rem;display:flex}.socratic-prompt__header{align-items:flex-start;gap:.5rem;display:flex}.socratic-prompt__icon{flex-shrink:0;font-size:1.1rem}.socratic-prompt__intro{color:var(--color-text);font-size:.83rem;font-weight:500;line-height:1.4}.socratic-prompt__questions{counter-reset:q-counter;flex-direction:column;gap:.4rem;padding:0;list-style:none;display:flex}.socratic-prompt__question{color:var(--color-text-muted);counter-increment:q-counter;border-left:2px solid var(--color-border);border-radius:0 var(--radius) var(--radius) 0;background:#4a9eff0a;align-items:flex-start;gap:.5rem;padding:.35rem .5rem;font-size:.81rem;line-height:1.45;display:flex}.socratic-prompt__question:before{content:counter(q-counter) ".";color:var(--color-accent);flex-shrink:0;min-width:1rem;font-size:.78rem;font-weight:700}.socratic-prompt__reveal-btn{background:var(--color-accent);color:#fff;border-radius:var(--radius);cursor:pointer;border:none;align-self:flex-start;margin-top:.1rem;padding:.4rem .85rem;font-size:.82rem;font-weight:600;transition:background .15s}.socratic-prompt__reveal-btn:hover{background:var(--color-accent-hover)}.coach-panel__admin{border-top:1px solid var(--border);flex-direction:column;gap:.35rem;margin-top:.75rem;padding:.5rem .75rem;display:flex}.coach-panel__reset-btn{color:#f87171;cursor:pointer;background:#dc323226;border:1px solid #dc323259;border-radius:6px;padding:.35rem .6rem;font-size:.78rem;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{color:#a3e635;margin:0;font-size:.75rem}.profile-admin-badge{color:#c4b5fd;background:#7c3aed33;border:1px solid #7c3aed66;border-radius:999px;align-items:center;gap:.3rem;padding:.15rem .55rem;font-size:.78rem;font-weight:600;display:inline-flex}.profile-admin-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:.9rem;display:grid}.profile-admin-card{background:#ffffff0a;border:1px solid #ffffff14;border-radius:10px;flex-direction:column;gap:.65rem;padding:.9rem 1rem;display:flex}.profile-admin-card--wide{grid-column:1/-1}.profile-admin-label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.74rem}.profile-admin-value{color:var(--color-text);font-size:1.05rem}.profile-admin-value.is-live{color:#86efac}.profile-admin-actions{flex-wrap:wrap;gap:.55rem;display:flex}.profile-admin-stats{grid-template-columns:repeat(4,minmax(0,1fr));gap:.75rem;display:grid}.profile-admin-stat{background:#ffffff08;border-radius:8px;flex-direction:column;gap:.3rem;padding:.7rem .8rem;display:flex}.profile-admin-stat span{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:.72rem}.profile-admin-stat strong{color:var(--color-text);font-size:1rem}.profile-admin-message{color:#86efac;margin-top:.75rem;font-size:.84rem}.profile-admin-message.is-error{color:#fca5a5}.profile-ratings-grid{grid-template-columns:repeat(2,1fr);gap:.75rem;margin-top:.25rem;display:grid}@media (width<=760px){.profile-admin-grid{grid-template-columns:1fr}.profile-admin-stats{grid-template-columns:repeat(2,minmax(0,1fr))}}.profile-rating-item{background:#ffffff0a;border:1px solid #ffffff14;border-radius:8px;flex-direction:column;gap:.4rem;padding:.6rem .75rem;display:flex}.profile-rating-mode{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.72rem}.profile-rating-value{color:var(--color-text);font-size:1.35rem;font-weight:700;line-height:1.2}.opening-label{color:var(--color-text-muted);text-align:center;opacity:.85;min-height:1.2rem;padding:.2rem .5rem;font-size:.8rem}.player-info-placeholder{pointer-events:none}.transcript-list{flex-direction:column;gap:1px;padding:.5rem .25rem;display:flex}.transcript-pair{align-items:center;gap:.3rem;padding:.15rem .25rem;font-size:.9rem;display:flex}.transcript-pair:hover{background:#ffffff0a;border-radius:4px}.transcript-movenum{color:var(--color-text-muted);text-align:right;flex-shrink:0;min-width:1.6rem;font-size:.8rem}.transcript-san{cursor:pointer;color:var(--color-text);border-radius:3px;min-width:3.2rem;padding:.1rem .35rem;transition:background .1s}.transcript-san:hover{background:#ffffff1a}.transcript-san.transcript-active{background:var(--color-accent,#4a9eff);color:#fff;font-weight:600}.play-page{flex:1;gap:1rem;min-height:0;display:flex}.play-page--setup{justify-content:center;align-items:center}.play-setup-wrapper{align-items:flex-start;gap:2.5rem;padding:2rem;display:flex}.play-setup-board-preview{flex-direction:column;gap:.5rem;display:flex}.play-setup-board-controls{color:var(--color-text-muted,#aaa);align-items:center;gap:.75rem;font-size:.85rem;display:flex}.play-setup-orientation-hint{color:var(--color-text-muted,#aaa);font-size:.85rem}.play-setup-panel{background:var(--color-panel,#1e1e1e);border:1px solid var(--color-border,#333);border-radius:8px;flex-direction:column;gap:1.5rem;min-width:280px;max-width:340px;padding:1.5rem;display:flex}.play-setup-title{margin:0;font-size:1.3rem;font-weight:700}.play-setup-section{flex-direction:column;gap:.5rem;display:flex}.play-setup-label{text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted,#aaa);font-size:.78rem;font-weight:600}.play-setup-elo-display{align-items:baseline;gap:.4rem;margin-bottom:.25rem;display:flex}.play-setup-elo-number{font-size:1.4rem;font-weight:700}.play-setup-elo-label{color:var(--color-text-muted,#aaa);font-size:.9rem}.play-setup-slider{width:100%;accent-color:var(--color-accent,#4a9eff);cursor:pointer}.play-setup-slider-ticks{color:var(--color-text-muted,#aaa);justify-content:space-between;font-size:.72rem;display:flex}.play-setup-pills{flex-wrap:wrap;gap:.4rem;display:flex}.play-setup-pill{border:1px solid var(--color-border,#444);color:var(--color-text,#eee);cursor:pointer;background:0 0;border-radius:20px;padding:.35rem .85rem;font-size:.85rem;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{background:var(--color-accent,#4a9eff);color:#fff;cursor:pointer;border:none;border-radius:6px;margin-top:.5rem;padding:.7rem 1.2rem;font-size:1rem;font-weight:700;transition:opacity .15s}.play-setup-start-btn:hover{opacity:.88}.play-board-controls{gap:.5rem}.bot-thinking-indicator{color:var(--color-text-muted,#aaa);text-align:center;background:#ffffff0a;border-radius:6px;margin-bottom:.5rem;padding:.4rem .75rem;font-size:.82rem}.bot-thinking-dots:after{content:"";animation:1.2s steps(4,end) infinite thinking-dots}@keyframes thinking-dots{0%{content:""}25%{content:"."}50%{content:".."}75%{content:"..."}to{content:""}}.game-result-banner{background:var(--color-panel,#1e1e1e);text-align:center;border-top:3px solid #0000;border-radius:10px;flex-direction:column;align-items:center;gap:.35rem;margin-top:.75rem;padding:1.25rem 1.25rem 1.5rem;display:flex}.game-result-banner--win{background:#4ade800d;border-top-color:#4ade80}.game-result-banner--loss{background:#f871710d;border-top-color:#f87171}.game-result-banner--draw{background:#94a3b80d;border-top-color:#94a3b8}.game-result-icon{margin-bottom:.1rem;font-size:2rem;line-height:1}.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{letter-spacing:-.01em;font-size:1.6rem;font-weight:700}.game-result-subtitle{color:var(--color-text-muted,#aaa);text-transform:capitalize;margin-bottom:.25rem;font-size:.82rem}.game-result-actions{justify-content:center;gap:.6rem;width:100%;margin-top:.5rem;display:flex}.game-result-btn{border:1px solid var(--color-border,#444);cursor:pointer;border-radius:6px;flex:1;padding:.55rem .75rem;font-size:.85rem;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{color:var(--color-text,#eee);background:0 0}.game-result-btn:hover{opacity:.82}.browse-mode-banner{background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text-muted);justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:.5rem;padding:.4rem .75rem;font-size:.8rem;display:flex}.play-eval-lines{border:1px solid var(--color-border);border-radius:var(--radius);flex-direction:column;gap:.25rem;margin-top:.5rem;padding:.5rem;font-size:.8rem;display:flex}.play-eval-line{align-items:baseline;gap:.5rem;display:flex}.play-eval-score{color:var(--color-accent);font-variant-numeric:tabular-nums;min-width:3rem;font-weight:600}.play-eval-moves{color:var(--color-text-muted);font-family:var(--font-mono,monospace);text-overflow:ellipsis;white-space:nowrap;font-size:.75rem;overflow:hidden}.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{flex-direction:column;height:100%;display:flex;overflow:hidden}.coach-panel--empty{text-align:center;justify-content:center;align-items:center;padding:2rem 1rem}.coach-panel__analyzing-bar{background:var(--color-surface-2,#ffffff0a);border-bottom:1px solid var(--color-border);color:var(--color-text-muted);flex-shrink:0;align-items:center;gap:.5rem;padding:.4rem .75rem;font-size:.8rem;display:flex}.coach-narrative{flex:1;padding:.25rem 0;overflow-y:auto}.coach-narrative__move-pair{flex-direction:column;display:flex}.coach-narrative__row{border-left:2px solid #0000;flex-direction:column;padding:.2rem .75rem;transition:background .1s;display:flex}.coach-narrative__row:hover{background:var(--color-surface-2,#ffffff08)}.coach-narrative__row--critical{border-left-color:var(--color-accent,#f59e0b);background:#f59e0b0a;margin:.25rem 0;padding-top:.5rem;padding-bottom:.5rem}.coach-narrative__move-btn{cursor:pointer;text-align:left;width:100%;color:var(--color-text);background:0 0;border:none;align-items:center;gap:.35rem;padding:0;display:flex}.coach-narrative__move-label{font-family:var(--font-mono,monospace);white-space:nowrap;font-size:.82rem;font-weight:500}.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{border-radius:50%;flex-shrink:0;width:7px;height:7px;margin-left:2px}.coach-narrative__comment{color:var(--color-text-muted);margin:.1rem 0 0;font-size:.76rem;line-height:1.4}.coach-narrative__lesson{margin-top:.5rem}.coach-panel__loading--inline{color:var(--color-text-muted);align-items:center;gap:.5rem;padding:.4rem 0;font-size:.8rem;display:flex}.coach-panel__error-inline{color:var(--color-error,#f87171);margin:.25rem 0 0;font-size:.78rem}.coach-panel__empty-msg--inline{color:var(--color-text-muted);margin:0;padding:1rem .75rem;font-size:.82rem}.coach-panel__spinner--small{border-width:2px;width:12px;height:12px}.move-coach-comment{border-radius:var(--radius);background:var(--color-surface-2,#ffffff08);border:1px solid var(--color-border);min-height:2.5rem;margin:0 0 .5rem;padding:.5rem .75rem;transition:border-color .15s}.move-coach-comment--critical{border-color:var(--color-accent,#f59e0b);background:#f59e0b0d}.move-coach-comment__badge{letter-spacing:.04em;text-transform:uppercase;white-space:nowrap;border:1px solid;border-radius:3px;flex-shrink:0;align-items:center;padding:.1rem .35rem;font-size:.67rem;font-weight:700;display:inline-flex}.move-coach-comment__text{color:var(--color-text-muted);margin:0;font-size:.8rem;line-height:1.45}.move-coach-comment__lesson{border-top:1px solid var(--color-border);margin-top:.4rem;padding-top:.4rem}.move-coach-comment__lesson-text{color:var(--color-text);margin:0;font-size:.82rem;line-height:1.55}.move-coach-comment__loading{color:var(--color-text-muted);margin:0;font-size:.78rem;font-style:italic}.move-coach-comment__error{color:var(--color-error,#f87171);margin:0;font-size:.78rem}.game-transcript{flex:1;min-height:0;padding:.25rem 0;font-size:.82rem;overflow-y:auto}.game-transcript--empty{justify-content:center;align-items:center;padding:1.5rem 1rem;display:flex}.game-transcript__placeholder{color:var(--color-text-muted);text-align:center;margin:0;font-size:.8rem}.transcript-pair{align-items:flex-start;gap:.25rem;padding:0 .5rem;display:flex}.transcript-pair__num{font-variant-numeric:tabular-nums;color:var(--color-text-muted);flex-shrink:0;min-width:1.8rem;padding-top:.25rem;font-size:.75rem}.transcript-pair__moves{flex-wrap:wrap;flex:1;gap:.15rem;display:flex}.transcript-move{border-radius:4px;flex:1;min-width:0;padding:.2rem .35rem;transition:background .1s}.transcript-move--active{background:var(--color-surface-active,#ffffff1a)}.transcript-move--critical{border-left:2px solid var(--color-accent,#f59e0b)}.transcript-move__token-row{align-items:center;gap:.3rem;display:flex}.transcript-move__btn{cursor:pointer;color:var(--color-text);background:0 0;border:none;align-items:center;gap:.25rem;padding:0;font-size:.82rem;display:flex}.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{border-radius:50%;flex-shrink:0;width:6px;height:6px}.transcript-move__lesson-btn{cursor:pointer;color:var(--color-text-muted);opacity:.7;background:0 0;border:none;margin-left:auto;padding:0 .2rem;font-size:.65rem;line-height:1}.transcript-move__lesson-btn:hover{opacity:1;color:var(--color-accent,#f59e0b)}.transcript-move__comment{color:var(--color-text-muted);margin:.1rem 0 0;font-size:.73rem;line-height:1.4}.transcript-move__lesson{background:var(--color-surface-2,#ffffff0a);border:1px solid var(--color-border);border-radius:4px;margin-top:.4rem;padding:.5rem .6rem}.transcript-move__lesson-badge{letter-spacing:.04em;text-transform:uppercase;border:1px solid;border-radius:3px;margin-bottom:.35rem;padding:.1rem .35rem;font-size:.68rem;font-weight:600;display:inline-block}.transcript-move__lesson-text{color:var(--color-text);margin:0;font-size:.8rem;line-height:1.55}.transcript-move__lesson-loading,.transcript-move__lesson-error{margin:0;font-size:.78rem;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);margin:0;font-size:.78rem;font-style:italic}.move-coach-comment__view-lesson-btn{border:1px solid var(--color-border);color:var(--color-text-muted);cursor:pointer;background:0 0;border-radius:4px;margin-top:.5rem;padding:.25rem .6rem;font-size:.75rem;transition:border-color .15s,color .15s;display:inline-block}.move-coach-comment__view-lesson-btn:hover{color:var(--color-accent,#f59e0b);border-color:var(--color-accent,#f59e0b)}.move-coach-comment__best-move-btn{color:#a0c4ff;cursor:pointer;background:0 0;border:1px solid #a0c4ff59;border-radius:4px;margin-top:.5rem;padding:.3rem .75rem;font-size:.78rem;font-weight:500;transition:color .15s,border-color .15s,background .15s}.move-coach-comment__best-move-btn:hover{color:#fff;background:#a0c4ff14;border-color:#a0c4ffb3}.lesson-nav{flex-wrap:wrap;flex-shrink:0;align-items:center;gap:.4rem;display:flex}.lesson-nav__label{color:var(--color-text-muted,#64748b);white-space:nowrap;flex-shrink:0;font-size:.7rem}.lesson-nav__next-btn{color:var(--color-text-muted,#64748b);cursor:pointer;white-space:nowrap;background:0 0;border:none;padding:0 .2rem;font-size:.7rem;transition:color .15s}.lesson-nav__next-btn:hover{color:var(--color-accent,#f59e0b)}.lesson-dots{flex-shrink:0;align-items:center;gap:.3rem;display:flex}.lesson-dot{border:1.5px solid var(--color-border,#ffffff26);width:18px;height:18px;color:var(--color-text-muted,#64748b);cursor:pointer;background:0 0;border-radius:50%;justify-content:center;align-items:center;padding:0;font-size:.62rem;font-weight:700;line-height:1;transition:border-color .15s,color .15s,background .15s;display:inline-flex}.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:1.2s ease-in-out infinite lesson-dot-pulse}@keyframes lesson-dot-pulse{0%,to{opacity:.45}50%{opacity:.8}}.lesson-dot__num{line-height:1}.lesson-dot__spinner{border:1.5px solid;border-top-color:#0000;border-radius:50%;width:8px;height:8px;animation:.7s linear infinite lesson-dot-spin;display:inline-block}@keyframes lesson-dot-spin{to{transform:rotate(360deg)}}.move-coach-comment__header{justify-content:space-between;align-items:flex-start;gap:.5rem;display:flex}.move-coach-comment__header-text{min-width:0;color:var(--color-text-muted,#94a3b8);flex-wrap:wrap;flex:1;align-items:center;gap:.4rem;font-size:.8rem;display:flex}.move-coach-comment__analyzing-dot{background:var(--color-accent,#f59e0b);border-radius:50%;flex-shrink:0;width:7px;height:7px;animation:1.2s ease-in-out infinite coach-analyzing-pulse;display:inline-block}@keyframes coach-analyzing-pulse{0%,to{opacity:1}50%{opacity:.3}}.practice-page{grid-template-columns:minmax(280px,340px) minmax(0,1fr);align-items:start;gap:1.25rem;width:100%;display:grid}.practice-sidebar,.practice-main{min-width:0}.practice-sidebar{gap:1rem;display:grid}.practice-sidebar__section,.practice-hero,.practice-browser,.practice-study__board,.practice-study__notes{background:linear-gradient(#171d2bf5 0%,#10141ff5 100%);border:1px solid #7a89ad2e;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{color:#f7f8fb;margin:0}.practice-title{margin-top:.25rem;font-size:2rem;line-height:1.05}.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{gap:.75rem;display:grid}.practice-course-card,.practice-line-card,.practice-chip,.practice-mode-tab{color:#eef2fb;background:#ffffff08;border:1px solid #8c9bc22e;transition:border-color .12s,background .12s,transform .12s}.practice-course-card,.practice-line-card{text-align:left;cursor:pointer;border-radius:16px;width:100%;padding:.9rem 1rem}.practice-course-card:hover,.practice-line-card:hover,.practice-chip:hover,.practice-mode-tab:hover:not(:disabled){background:#78c7be14;border-color:#78c7be8c;transform:translateY(-1px)}.practice-course-card.active,.practice-line-card.active,.practice-chip.active,.practice-mode-tab.active{background:linear-gradient(#54baab2e 0%,#54baab14 100%);border-color:#78c7bee6}.practice-course-card__top,.practice-line-card__top,.practice-study__header,.practice-hero{justify-content:space-between;align-items:start;gap:.75rem;display:flex}.practice-course-card__badge{color:#cfd8ff;background:#5970ff2e;border-radius:999px;align-items:center;padding:.18rem .5rem;font-size:.72rem;font-weight:700;display:inline-flex}.practice-course-card__title,.practice-line-card__title,.practice-target-move,.practice-stat__value{color:#f6f8fc;font-weight:700}.practice-course-card__title,.practice-line-card__title{font-size:1rem}.practice-coming-soon__item{color:#d6dcef;background:#ffffff09;border-radius:14px;padding:.7rem .8rem}.practice-main{gap:1rem;display:grid}.practice-hero{padding:1.1rem 1.2rem}.practice-hero__title{font-size:1.7rem}.practice-hero__copy{max-width:52rem;margin:.45rem 0 0}.practice-hero__stats{flex-wrap:wrap;gap:.75rem;display:flex}.practice-stat{background:#ffffff0a;border-radius:16px;min-width:96px;padding:.75rem .9rem}.practice-stat__value{margin-top:.18rem;font-size:1.1rem;display:block}.practice-mode-tabs{gap:.55rem;display:inline-flex}.practice-mode-tab{cursor:pointer;border-radius:999px;padding:.65rem 1rem;font-weight:700}.practice-mode-tab--disabled{opacity:.55;cursor:not-allowed}.practice-workspace{grid-template-columns:minmax(280px,360px) minmax(0,1fr);align-items:start;gap:1rem;display:grid}.practice-browser,.practice-study__board,.practice-study__notes{padding:1rem}.practice-chip-row{flex-wrap:wrap;gap:.55rem;margin-bottom:1rem;display:flex}.practice-chip{cursor:pointer;border-radius:999px;padding:.55rem .85rem;font-weight:700}.practice-study{grid-template-columns:minmax(320px,1.05fr) minmax(280px,.95fr);align-items:start;gap:1rem;display:grid}.practice-progress-pill{color:#bfe7e0;background:#78c7be1f;border-radius:999px;align-items:center;padding:.45rem .7rem;display:inline-flex}.practice-board-shell{aspect-ratio:1;width:min(100%,540px);margin:1rem 0 .9rem;position:relative}.practice-history{flex-wrap:wrap;gap:.5rem;display:flex}.practice-history__move,.practice-history__empty{color:#dce3f5;background:#ffffff0d;border-radius:999px;padding:.35rem .55rem;font-size:.88rem}.practice-history__empty{color:#95a2c3}.practice-target-move{margin-top:.35rem;font-size:2.2rem;line-height:1}.practice-target-explanation{margin:.75rem 0 0}.practice-feedback{color:#d5dcf0;background:#ffffff0a;border-radius:16px;margin-top:.95rem;padding:.85rem .95rem;line-height:1.5}.practice-alt-box{background:#ffffff0a;border-radius:16px;margin-top:1rem;padding:.85rem}.practice-alt-box__item{color:#d5dcf0;gap:.28rem;display:grid}.practice-alt-box__item+.practice-alt-box__item{margin-top:.7rem}.practice-alt-box__move{color:#f6f8fc;font-weight:700}.practice-nav{gap:.75rem;margin-top:1.2rem;display:flex}.practice-nav__btn{min-width:140px}@media (width<=1279px){.practice-page,.practice-workspace,.practice-study{grid-template-columns:1fr}.practice-board-shell{width:min(100%,480px)}}@media (width<=639px){.practice-page{gap:.9rem}.practice-sidebar__section,.practice-hero,.practice-browser,.practice-study__board,.practice-study__notes{border-radius:18px;padding:.9rem}.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{padding-right:.2rem;overflow-y:auto}.practice-panel-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);flex-direction:column;gap:.7rem;padding:.85rem;display:flex}.practice-mode-toggle,.practice-panel-actions{grid-template-columns:repeat(2,minmax(0,1fr));gap:.5rem;display:grid}.practice-mode-toggle__btn,.practice-panel-actions .board-control-btn{justify-content:center;width:100%}.practice-panel-actions__wide{grid-column:1/-1;justify-content:center}.practice-panel-card__eyebrow,.practice-panel-section-label,.practice-panel-stat__label{text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted);font-size:.72rem;font-weight:700}.practice-panel-card__title{color:var(--color-text);margin:0;font-size:1.15rem}.practice-panel-copy{color:var(--color-text-muted);margin:0;font-size:.92rem;line-height:1.5}.practice-panel-section-label:not(:first-child){margin-top:.15rem}.practice-panel-stats{grid-template-columns:repeat(3,minmax(0,1fr));gap:.5rem;display:grid}.practice-panel-stat{background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius);padding:.6rem}.practice-panel-stat__value{color:var(--color-text);margin-top:.18rem;font-weight:700;display:block}.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{letter-spacing:.06em;text-transform:uppercase;margin-top:.55rem;font-size:.76rem;font-weight:700}.practice-line-panel{min-height:0}.practice-line-list{max-height:none;padding-right:.2rem;overflow-y:visible}.practice-board-controls .board-controls__actions{justify-content:flex-end}.practice-mode-hint{flex:100%}.practice-feedback{color:var(--color-text-muted);background:#ffffff0a}.practice-feedback--success{color:#d4fae4;background:#4ade8021}.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{border-radius:4px;position:relative;overflow:hidden}.practice-board-flash--correct{animation:.55s ease-out forwards practice-flash-correct}.practice-board-flash--incorrect{animation:.55s ease-out forwards practice-flash-incorrect}.practice-feedback--incorrect{color:#fdd5d5;background:#ef44441f}.practice-feedback--revealed{color:var(--color-text);background:#4a9eff1f}.practice-notation{flex-wrap:wrap;gap:1px;font-size:.9rem;line-height:2;display:flex}.practice-notation-pair{align-items:baseline;gap:.2rem;margin-right:.5rem;display:inline-flex}.practice-notation__num{color:var(--color-text-muted);min-width:1.4rem;font-size:.78rem}.practice-notation-san{color:var(--color-text-muted);border-radius:3px;padding:.05rem .28rem;line-height:1.8}.practice-notation-san--user{color:var(--color-text);cursor:pointer}.practice-notation-san--user:hover{color:var(--color-accent);background:#4a9eff1a}.practice-notation-san--current{color:var(--color-accent);background:#4a9eff33;font-weight:700}.practice-preview-header{justify-content:space-between;align-items:flex-start;gap:.75rem;margin-bottom:.25rem;display:flex}.practice-preview-cta{flex-shrink:0}.practice-reps-header{justify-content:space-between;align-items:center;margin-bottom:.1rem;display:flex}.practice-reps-step{color:var(--color-text-muted);font-variant-numeric:tabular-nums;font-size:.8rem}.practice-reps-primary-btn{justify-content:center;width:100%;margin-top:.85rem}.practice-reps-secondary{justify-content:space-between;margin-top:.55rem;display:flex}.practice-reps-link{cursor:pointer;color:var(--color-text-muted);background:0 0;border:none;padding:.2rem 0;font-size:.82rem;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{color:var(--color-text-muted);font-size:.83rem;font-family:var(--font-mono);word-break:break-word;margin-top:.55rem;line-height:1.6}@media (width<=1023px){.practice-panel-stats{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (width>=1181px){.side-col{flex:280px;width:auto;min-width:280px;max-width:440px}}.ad-col{flex-direction:column;flex:0 0 160px;align-self:stretch;width:160px;display:flex}.ad-placeholder{border:1px dashed var(--color-border);border-radius:var(--radius);width:160px;min-height:160px;color:var(--color-text-muted);text-align:center;letter-spacing:.04em;text-transform:uppercase;background:#ffffff08;flex:1;justify-content:center;align-items:center;font-size:.7rem;display:flex}@media (width<=1329px){.ad-col{display:none}}.coming-soon-panel{text-align:center;color:var(--text-secondary,#9aa0ad);padding:2rem 1.25rem}.coming-soon-panel h3{color:var(--text-primary,#e8eaed);margin-bottom:.75rem;font-size:1.1rem;font-weight:600}.coming-soon-panel p{margin-bottom:.5rem;font-size:.875rem;line-height:1.55}.coming-soon-sub{opacity:.7;font-size:.8rem}.coming-soon-overlay{z-index:2;pointer-events:all;background:#0f0f14d1;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.coming-soon-badge{background:var(--color-surface);border:1px solid var(--color-border);text-align:center;border-radius:16px;flex-direction:column;gap:.5rem;padding:2rem 3.5rem;display:flex}.coming-soon-badge__title{color:var(--color-text);letter-spacing:.02em;font-size:2rem;font-weight:700}.coming-soon-badge__sub{color:var(--color-text-muted);font-size:.95rem}.coming-soon-card{background:var(--color-surface);border:1px solid var(--color-border);text-align:center;border-radius:16px;flex-direction:column;gap:.5rem;padding:2rem 3.5rem;display:flex}.coming-soon-card h2{color:var(--color-text);letter-spacing:.02em;margin:0;font-size:2rem;font-weight:700}.coming-soon-card p{color:var(--color-text-muted);margin:0;font-size:.95rem}.practice-coming-soon-page{flex:auto;justify-content:center;align-self:stretch;align-items:center;min-height:0;display:flex;position:relative;overflow:hidden}.practice-coming-soon-board{aspect-ratio:1;opacity:.25;pointer-events:none;filter:blur(2px);width:min(520px,100vh - 120px,80vw)}*,: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{flex-direction:row;height:100vh;display:flex;overflow:hidden}.app-content{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.app-shell__backdrop,.app-header{display:none}.app-header{min-height:var(--layout-header-height);border-bottom:1px solid var(--color-border);background:var(--color-surface);z-index:15;flex-shrink:0;align-items:center;gap:.75rem;padding:.75rem 1rem;position:sticky;top:0}.app-header__menu{border:1px solid var(--color-border);background:var(--color-surface-2);color:var(--color-text);border-radius:var(--radius);cursor:pointer;padding:.4rem .5rem;font-size:1.1rem;font-weight:400;transition:border-color .15s,color .15s,background .15s}.app-header__menu:hover{border-color:var(--color-accent);color:var(--color-accent)}.app-header__brand{align-items:center;gap:.55rem;min-width:0;display:flex}.app-header__brand-mark{flex-shrink:0;width:30px;height:30px}.app-header__brand-name{letter-spacing:-.02em;color:var(--color-text);font-size:1rem;font-weight:700}.app-header__page{color:var(--color-text-muted);letter-spacing:.08em;text-transform:uppercase;margin-left:auto;font-size:.74rem;font-weight:700}html.theme-light{--color-bg:#f0f2f5;--color-surface:#fff;--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 (width<=1023px){.app-shell--compact-nav .app-shell__backdrop{opacity:0;pointer-events:none;z-index:20;background:#080c18a8;border:0;padding:0;transition:opacity .18s;display:block;position:fixed;inset:0}.app-shell--compact-nav.app-shell--nav-open .app-shell__backdrop{opacity:1;pointer-events:auto}.app-shell--compact-nav .nav-sidebar{z-index:30;width:min(84vw,220px);max-width:220px;height:100vh;transition:transform .18s;position:fixed;top:0;bottom:0;left:0;transform:translate(-100%);box-shadow:24px 0 48px #00000057}.app-shell--compact-nav.app-shell--nav-open .nav-sidebar{transform:translate(0)}.app-shell--compact-nav .app-header{display:flex}}@media (width<=860px){html,body{overflow:hidden auto}.app{flex-direction:column;height:auto;min-height:100vh;overflow:visible}.app-content{min-width:0;max-width:100%}}@media (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{flex-direction:column;justify-content:center;gap:.15rem;padding:.35rem 0}.app-shell--nav-collapsed .nav-logo__img{width:30px;height:30px}.app-shell--nav-collapsed .nav-item{border-left-color:#0000;justify-content:center;padding:.6rem 0}.app-shell--nav-collapsed .nav-item.active{background:#4a9eff1a;border-left-color:#0000}.nav-divider{background:var(--color-border);height:1px;margin:.3rem .75rem}.app-shell--nav-collapsed .nav-divider{margin:.3rem .4rem}@media (width>=1330px){:root{--board-vw-offset:724px}}.mobile-ad-banner{z-index:200;background:var(--color-surface);border-top:1px solid var(--color-border);justify-content:center;align-items:center;min-height:56px;padding:3px 36px 3px 0;display:flex;position:fixed;bottom:0;left:0;right:0}.mobile-ad-banner__close{color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;padding:4px 6px;font-size:1.4rem;line-height:1;position:absolute;top:50%;right:8px;transform:translateY(-50%)}.mobile-ad-banner__close:hover{color:var(--color-text)}@media (width>=768px){.mobile-ad-banner{display:none}}@media (width<=767px){.app-content{padding-bottom:56px}}.app-footer{text-align:center;border-top:1px solid var(--color-border);margin-top:auto;padding:.75rem 1rem}.app-footer__link{color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;padding:0;font-size:.75rem;text-decoration:underline}.app-footer__link:hover{color:var(--color-text)}.privacy-page{max-width:720px;margin:0 auto;padding:2rem 1.5rem 4rem}.privacy-page h1{margin-bottom:.25rem;font-size:1.5rem}.privacy-page__updated{color:var(--color-text-muted);margin-bottom:2rem;font-size:.8rem}.privacy-page h2{margin-top:1.75rem;margin-bottom:.4rem;font-size:1rem}.privacy-page p{color:var(--color-text-secondary,var(--color-text-muted));font-size:.875rem;line-height:1.6}.privacy-page a{color:var(--color-accent,#4a9eff)}
