.cg-wrap{box-sizing:content-box;position:relative;display:block}cg-container{position:absolute;width:100%;height:100%;display:block;top:0}cg-board{position:absolute;top:0;left:0;width:100%;height:100%;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;line-height:0;background-size:cover}.cg-wrap.manipulable cg-board{cursor:pointer}cg-board square{position:absolute;top:0;left:0;width:12.5%;height:12.5%;pointer-events:none}cg-board square.move-dest{pointer-events:auto}cg-board square.last-move{will-change:transform}.cg-wrap piece{position:absolute;top:0;left:0;width:12.5%;height:12.5%;background-size:cover;z-index:2;will-change:transform;pointer-events:none}cg-board piece.dragging{cursor:move;z-index:11!important}piece.anim{z-index:8}piece.fading{z-index:1;opacity:.5}.cg-wrap piece.ghost{opacity:.3}.cg-wrap piece svg{overflow:hidden;position:relative;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:2;opacity:.6}.cg-wrap cg-auto-pieces,.cg-wrap .cg-shapes,.cg-wrap .cg-custom-svgs{overflow:visible;position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none}.cg-wrap cg-auto-pieces{z-index:2}.cg-wrap cg-auto-pieces piece{opacity:.3}.cg-wrap .cg-shapes{overflow:hidden;opacity:.6;z-index:2}.cg-wrap .cg-custom-svgs{z-index:9}.cg-wrap .cg-custom-svgs svg{overflow:visible}.cg-wrap coords{position:absolute;display:flex;pointer-events:none;opacity:.8;font-family:sans-serif;font-size:9px}.cg-wrap coords.ranks{left:4px;top:-20px;flex-flow:column-reverse;height:100%;width:12px}.cg-wrap coords.ranks.black{flex-flow:column}.cg-wrap coords.ranks.left{left:-15px;align-items:flex-end}.cg-wrap coords.files{bottom:-4px;left:24px;flex-flow:row;width:100%;height:16px;text-transform:uppercase;text-align:center}.cg-wrap coords.files.black{flex-flow:row-reverse}.cg-wrap coords coord{flex:1 1 auto}.cg-wrap coords.ranks coord{transform:translateY(39%)}.cg-wrap coords.squares{bottom:0;left:0;text-transform:uppercase;text-align:right;flex-flow:column-reverse;height:100%;width:12.5%}.cg-wrap coords.squares.black{flex-flow:column}.cg-wrap coords.squares.left{text-align:left}.cg-wrap coords.squares coord{padding:6% 4%}.cg-wrap coords.squares.rank2{transform:translate(100%)}.cg-wrap coords.squares.rank3{transform:translate(200%)}.cg-wrap coords.squares.rank4{transform:translate(300%)}.cg-wrap coords.squares.rank5{transform:translate(400%)}.cg-wrap coords.squares.rank6{transform:translate(500%)}.cg-wrap coords.squares.rank7{transform:translate(600%)}.cg-wrap coords.squares.rank8{transform:translate(700%)}.cg-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{color:#1d2522;background:#f4f1ea;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}button,a{font:inherit}.login-view,.loading-view{min-height:100vh;display:grid;place-items:center;padding:24px;background:linear-gradient(180deg,#f4f1eae0,#f4f1eaf5),url(https://images.unsplash.com/photo-1529699211952-734e80c4d42b?auto=format&fit=crop&w=1800&q=80) center/cover}.login-panel{width:min(520px,100%);background:#ffffffeb;border:1px solid #d8d0c1;border-radius:8px;padding:28px;box-shadow:0 18px 50px #1f23202e}.eyebrow{margin:0 0 8px;color:#637067;font-size:12px;font-weight:700;letter-spacing:0;text-transform:uppercase}h1{margin:0;font-size:34px;line-height:1.08;letter-spacing:0}.login-copy{margin:14px 0 24px;color:#5b655f}.persona-button{width:100%;border:1px solid #bac7bd;border-radius:8px;padding:14px;background:#fff;color:#1d2522;display:flex;align-items:center;gap:12px;text-align:left;cursor:pointer}.persona-button:hover{border-color:#2c6e49;background:#f7fbf8}.persona-avatar{width:42px;height:42px;border-radius:50%;background:#2c6e49;color:#fff;display:grid;place-items:center;font-weight:800}.persona-button strong,.persona-button small{display:block}.persona-list,.local-user-form{display:grid;gap:12px}.persona-button small{color:#657069}.local-user-form{margin-top:18px}.local-user-form button{border:1px solid #aeb9b1;border-radius:8px;background:#fff;color:#1d2522;padding:10px 12px;cursor:pointer}.form-error{color:#9f2f2f;margin:14px 0 0}.app-shell{min-height:100vh;padding:28px;background:#f4f1ea}.training-budget-panel{max-width:1180px;margin:0 auto 20px;padding:18px 20px;border:1px solid #d8d0c1;border-radius:12px;background:#fffdf8;display:flex;align-items:end;justify-content:space-between;gap:20px}.linked-accounts-panel{max-width:1180px;margin:0 auto 20px;padding:18px 20px;border:1px solid #d8d0c1;border-radius:12px;background:#fffdf8;display:grid;gap:16px}.training-budget-panel h2{margin:0;font-size:22px}.training-budget-controls,.linked-account-list,.linked-account-form{display:flex;align-items:end;gap:10px;flex-wrap:wrap}.linked-account-chip{display:inline-flex;align-items:center;gap:8px;border:1px solid #d7ddd7;border-radius:999px;background:#f7fbf8;padding:8px 12px;color:#1d2522;cursor:pointer}.linked-account-chip.active{border-color:#2c6e49;background:#2c6e49;color:#fff}.linked-account-chip strong,.linked-account-chip span{display:inline-flex;align-items:center}.provider-favicon{width:16px;height:16px;border-radius:4px;flex:0 0 16px}.linked-account-chip.active .provider-favicon{background:#ffffffe6}.training-budget-label{display:flex;flex-direction:column;gap:6px;color:#59635d;font-size:14px}.training-budget-input{width:120px;border:1px solid #bac7bd;border-radius:8px;padding:10px 12px;background:#fff;color:#1d2522}.training-budget-controls button,.linked-account-form button{border:1px solid #aeb9b1;border-radius:8px;background:#fff;color:#1d2522;padding:10px 12px;cursor:pointer}.topbar{max-width:1180px;margin:0 auto 22px;display:flex;align-items:end;justify-content:space-between;gap:16px}.home-link{color:inherit;text-decoration:none}.account-block{display:flex;align-items:center;gap:12px;color:#59635d;font-size:14px}.account-block button,.game-link{border:1px solid #aeb9b1;border-radius:6px;background:#fff;color:#1d2522;padding:8px 11px;text-decoration:none;cursor:pointer}.game-browser{max-width:1180px;margin:0 auto}.review-shell{display:grid;grid-template-columns:minmax(0,1fr) 34rem;gap:18px;margin-bottom:18px;align-items:start}.review-main,.review-sidebar{min-width:0;border-radius:18px;overflow:hidden;border:1px solid #2e3330;background:#171a19;color:#f4f0e8}.review-main{padding:18px;background:radial-gradient(circle at top left,rgba(132,171,101,.18),transparent 30%),linear-gradient(180deg,#191c1b,#121413)}.review-sidebar{padding:20px;background:linear-gradient(180deg,#1f2221,#161817)}.review-header{display:flex;align-items:start;justify-content:space-between;gap:16px;margin-bottom:16px}.review-nav-row{margin-bottom:18px}.back-link{border:0;padding:0;margin:0 0 10px;background:transparent;color:#9bb98d;font-size:13px;cursor:pointer}.back-link.prominent{margin:0;border:1px solid #40503f;border-radius:999px;padding:10px 14px;background:#ffffff0a;color:#dce7c8;font-weight:700}.review-header h2,.review-sidebar h3{margin:0;color:#f8f4ea;font-size:28px;line-height:1.05}.review-result-line{margin:10px 0 0;font-size:18px;font-weight:700}.review-result-line.result-win{color:#bfe08f}.review-result-line.result-loss{color:#ffb0bb}.review-result-line.result-draw{color:#ead28f}.review-meta-chip-row{display:flex;flex-wrap:wrap;justify-content:end;gap:8px}.review-chip{border:1px solid #38413c;border-radius:999px;padding:8px 10px;color:#ced6d0;font-size:12px;background:#ffffff08}.review-chip-link{display:inline-flex;align-items:center;gap:6px;text-decoration:none}.review-summary-meta{margin-top:12px}.review-summary-chip{display:inline-flex;align-items:center;border-radius:999px;padding:8px 10px;background:#8fba541f;color:#dbe8c8;font-size:12px;font-weight:700;text-transform:uppercase}.review-player-banner{display:grid;grid-template-columns:minmax(0,1fr) auto minmax(0,1fr);align-items:center;gap:12px;margin-bottom:16px}.review-player-card{border:1px solid #38413c;border-radius:14px;padding:12px;background:#ffffff0a}.review-player-card.current-user{border-color:#8fba54;box-shadow:inset 0 0 0 1px #8fba5440}.review-player-label{display:block;margin-bottom:8px;color:#9ca8a0;font-size:11px;text-transform:uppercase}.review-player-line{display:flex;align-items:center;gap:10px}.review-player-line strong,.review-player-line span{display:block}.review-player-line strong{color:#f8f4ea}.review-player-line span:last-child{color:#98a39c;font-size:13px}.review-versus{color:#718077;font-size:12px;text-transform:uppercase}.review-board-shell{display:grid;gap:8px}.review-controls{display:grid;gap:10px;margin-top:16px;padding:14px;border:1px solid #36403b;border-radius:14px;background:#ffffff0a}.review-controls-row{display:flex;flex-wrap:wrap;gap:8px}.review-controls-row button,.move-list-header button,.move-pill{border:1px solid #40503f;border-radius:10px;background:#ffffff0a;color:#f4f0e8;cursor:pointer}.review-controls-row button,.move-list-header button{padding:8px 12px}.review-controls-row button:disabled,.move-pill:disabled{opacity:.45;cursor:not-allowed}.review-controls-meta{display:flex;flex-wrap:wrap;gap:12px;color:#bdc8c0;font-size:13px}.review-controls-meta strong{color:#f8f4ea}.review-board-row{display:grid;grid-template-columns:24px minmax(0,1fr);gap:10px;align-items:stretch}.board-rank-column,.board-file-row{display:grid}.board-rank-column{grid-template-rows:repeat(8,minmax(0,1fr))}.review-board{position:relative;aspect-ratio:1;overflow:hidden;border-radius:16px;border:1px solid #445042;background:#6d8f48}.board-squares-layer,.board-arrow-layer{position:absolute;inset:0}.board-squares-layer{z-index:1}.board-arrow-layer{z-index:2;pointer-events:none}.board-square{position:absolute;width:12.5%;height:12.5%;display:grid;place-items:center}.board-square.light{background:#f1ecd0}.board-square.dark{background:#7b9c55}.board-file-row{grid-template-columns:24px repeat(8,minmax(0,1fr));gap:10px}.board-axis-label{display:grid;place-items:center;color:#7f8b84;font-size:11px;font-weight:700;text-transform:uppercase}.board-piece{position:relative;z-index:1;width:82%;height:82%;object-fit:contain;filter:drop-shadow(0 4px 5px rgba(0,0,0,.14))}.board-arrow-line{stroke:#f2cf4a;stroke-width:1.1;stroke-linecap:round;opacity:.72}.board-arrow-line.solution{stroke:#7d9d68;stroke-width:1.4;opacity:.85}.review-sidebar-header{padding-bottom:16px;border-bottom:1px solid #313835}.review-sidebar-copy{margin:10px 0 0;color:#b9c3bc}.review-summary{display:grid;gap:18px}.move-list{display:grid;gap:10px}.move-list-header{display:flex;align-items:center;justify-content:space-between}.move-list-header span{color:#f8f4ea;font-weight:700}.move-list-body{max-height:320px;overflow:auto;scrollbar-gutter:stable;display:grid;gap:6px;padding-right:4px}.move-row{display:grid;grid-template-columns:38px minmax(0,1fr) minmax(0,1fr);gap:8px;align-items:center}.move-number{color:#97a39c;font-size:12px;font-weight:700}.move-pill{width:100%;padding:9px 10px;display:flex;align-items:center;justify-content:space-between;gap:8px;text-align:left}.move-pill.empty{justify-content:center}.move-pill-main{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.move-quality-badge{flex:0 0 auto;border-radius:999px;padding:4px 8px;font-size:10px;font-weight:700;text-transform:uppercase}.move-quality-badge.best{color:#d6f0b6;background:#77ab3138}.move-quality-badge.excellent{color:#c7ece8;background:#24bbae33}.move-quality-badge.inaccuracy{color:#f7dcab;background:#d9983b33}.move-quality-badge.mistake{color:#ffc3ae;background:#db683b33}.move-quality-badge.blunder{color:#ffb0bb;background:#d8435833}.move-quality-badge.neutral{color:#c7d0ca;background:#7a847f38}.move-pill.active{border-color:#8fba54;background:#8fba5429}.review-side-score-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.score-card,.analyze-callout{border:1px solid #36403b;border-radius:14px;background:#ffffff0a}.score-card{display:grid;gap:6px;padding:14px}.score-card-label{color:#99a59e;font-size:12px;text-transform:uppercase}.score-card strong{color:#f8f4ea;font-size:34px;line-height:1}.score-card span,.score-card small{color:#cad3ce}.breakdown-table{display:grid;gap:1px;border-radius:14px;overflow:hidden;background:#2b312f}.breakdown-header,.breakdown-row{display:grid;grid-template-columns:minmax(56px,1fr) minmax(120px,1.2fr) minmax(56px,1fr);gap:12px;align-items:center;padding:11px 14px;background:#1d211f}.breakdown-header{color:#97a39c;font-size:12px}.breakdown-header span:nth-child(2),.breakdown-row span{text-align:center}.breakdown-row strong{color:#f8f4ea;font-size:18px}.bucket-label{border-radius:999px;padding:6px 10px;font-size:11px;font-weight:700;text-transform:uppercase}.bucket-label.best{color:#d6f0b6;background:#77ab3138}.bucket-label.excellent{color:#c7ece8;background:#24bbae33}.bucket-label.inaccuracy{color:#f7dcab;background:#d9983b33}.bucket-label.mistake{color:#ffc3ae;background:#db683b33}.bucket-label.blunder{color:#ffb0bb;background:#d8435833}.analyze-first-card{display:grid;gap:16px}.analyze-callout{padding:14px}.analyze-callout strong,.analyze-callout code{display:block}.analyze-callout strong{margin-bottom:8px;color:#f8f4ea}.analyze-callout code{color:#dce7c8;font-size:12px;white-space:pre-wrap}.review-primary-link{display:inline-flex;width:fit-content;align-items:center;justify-content:center;border-radius:10px;padding:10px 14px;background:#8fba54;color:#10210e;font-weight:700;text-decoration:none}.content-note{color:#59635d;min-height:20px}.paginator{min-height:34px;display:flex;align-items:center;justify-content:space-between;gap:12px;margin:8px 0;color:#59635d;font-size:13px}.paginator.pending{opacity:.72}.paginator-controls{display:flex;align-items:center;gap:6px}.page-number-row{display:flex;align-items:center;gap:2px}.paginator-controls button,.page-number{border:1px solid transparent;border-radius:5px;background:transparent;color:#1d2522;padding:4px 7px;cursor:pointer}.paginator-controls button:hover:not(:disabled),.page-number:hover{border-color:#c4cec7;background:#fff}.paginator-controls>button{min-width:58px;color:#3f4a44}.page-number{min-width:28px}.page-number.active{border-color:#2c6e49;background:#2c6e49;color:#fff;font-weight:700}.page-ellipsis{min-width:20px;text-align:center;color:#79837d}.paginator-controls button:disabled{cursor:not-allowed;color:#a4aca7;background:transparent}.game-list{display:grid;gap:0;border:1px solid #ddd5c9;border-radius:8px;overflow:hidden;background:#fff}.game-list.pending{opacity:.62}.game-list-header,.game-row{display:grid;grid-template-columns:118px 88px minmax(260px,1fr) 58px minmax(130px,170px) 60px 110px 76px;align-items:center;gap:12px}.game-list-header{min-height:34px;padding:0 12px;background:#eee8dd;color:#68726c;font-size:12px;font-weight:750}.game-row{min-height:72px;border-top:1px solid #ebe5db;padding:8px 12px}.game-row.active{background:#f8f5ee}.result-win{color:#2c6e49}.result-draw{color:#8a6b24}.result-loss{color:#9f2f2f}.time-cell{display:grid;justify-items:start;gap:1px;color:#68726c;font-size:12px}.time-cell strong{color:#2c342f;font-size:13px}.profile-cell{display:flex;align-items:center;color:#59635d;font-size:12px}.provider-badge{display:inline-flex;align-items:center;gap:6px;border:1px solid #dde5de;border-radius:999px;background:#f7fbf8;padding:4px 8px;color:#2c342f;min-width:0}.provider-badge span{min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.time-icon{width:14px;height:14px;border:2px solid #78a84a;border-radius:50%;position:relative}.time-icon:before{content:"";position:absolute;width:5px;height:2px;left:5px;top:5px;background:#78a84a}.player-stack{min-width:0;display:grid;gap:3px}.player-line{display:flex;align-items:center;gap:7px;min-width:0;color:#3f4a44;font-size:13px}.player-line.current-user{color:#1d2522;font-weight:750}.player-avatar{width:20px;height:20px;border-radius:4px;object-fit:cover;flex:0 0 20px;background:#dfe6dd}.player-avatar.fallback{display:grid;place-items:center;color:#526058;font-size:11px;font-weight:750}.player-name{min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player-title{color:#8a6b24;margin-right:4px}.player-rating{color:#79837d;font-size:12px}.opening-line{display:flex;min-width:0;gap:8px;color:#79837d;font-size:12px;padding-left:27px}.opening-line span:last-child{min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.muted,.game-meta,.game-side span{color:#68726c}.scoreline{display:grid;gap:4px;justify-items:center;font-weight:800;font-size:13px}.accuracy-stack{display:grid;gap:3px;font-size:12px}.accuracy-line{display:flex;justify-content:space-between;gap:8px}.accuracy-line span{color:#68726c;text-transform:uppercase;font-size:11px}.accuracy-line strong{color:#2c342f}.accuracy-line.empty strong{color:#a4aca7}.moves-cell,.date-cell{color:#3f4a44;font-size:13px}.moves-cell{text-align:center}.date-cell{white-space:nowrap}.game-link{justify-self:end;padding:5px 9px;font-size:12px}.game-link.secondary{background:transparent}.game-actions{display:flex;justify-self:end;gap:8px}.game-side{display:grid;justify-items:end;font-size:14px}.preview-shell{min-height:100vh;display:grid;grid-template-columns:280px minmax(0,1fr);background:#f4f1ea}.preview-sidebar{position:sticky;top:0;align-self:start;height:100vh;overflow-y:auto;padding:22px 18px;border-right:1px solid #d8d0c1;background:#ece6d7;display:grid;gap:18px;align-content:start}.preview-sidebar-header{display:grid;gap:6px}.preview-sidebar-header h2{margin:0;font-size:20px}.preview-back-link{margin-top:8px;color:#2c6e49;font-weight:600;text-decoration:none;font-size:13px}.preview-back-link:hover{text-decoration:underline}.preview-group{display:grid;gap:6px}.preview-group-label{margin:0;color:#79837d;font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.preview-group-list{list-style:none;margin:0;padding:0;display:grid;gap:4px}.preview-state-link{display:grid;gap:2px;padding:9px 10px;border-radius:8px;border:1px solid transparent;text-decoration:none;color:#1d2522;background:transparent}.preview-state-link:hover{border-color:#d8d0c1;background:#fffdf8}.preview-state-link.active{border-color:#2c6e49;background:#fff}.preview-state-link strong{font-size:14px}.preview-state-link span{color:#79837d;font-size:12px;line-height:1.35}.preview-main{display:grid;grid-template-rows:auto minmax(0,1fr);min-width:0}.preview-toolbar{display:flex;align-items:end;justify-content:space-between;gap:16px;padding:18px 24px;border-bottom:1px solid #d8d0c1;background:#f4f1ea}.preview-toolbar-eyebrow{margin:0 0 4px;color:#79837d;font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.preview-toolbar-title{margin:0;font-size:22px}.preview-toolbar-actions button{border:1px solid #aeb9b1;border-radius:8px;background:#fff;color:#1d2522;padding:8px 12px;cursor:pointer}.preview-step-nav{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 24px;border-bottom:1px solid #d8d0c1;background:#ece6d7;font-size:13px}.preview-step-link{display:grid;gap:1px;padding:6px 12px;border-radius:8px;border:1px solid transparent;text-decoration:none;color:#1d2522;background:transparent;min-width:180px}.preview-step-link:hover:not(.disabled){border-color:#d8d0c1;background:#fffdf8}.preview-step-link.disabled{color:#aab1ac;cursor:not-allowed}.preview-step-link.next{text-align:right;justify-items:end}.preview-step-direction{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:#79837d}.preview-step-label{font-weight:600}.preview-step-position{color:#79837d}.preview-canvas{padding:24px;display:grid;align-content:start}.mock-onboarding{max-width:560px;margin:0 auto;display:grid;gap:14px}.mock-onboarding-topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:4px 2px}.mock-onboarding-wordmark{font-weight:800;letter-spacing:-.01em}.mock-onboarding-step{color:#79837d;font-size:12px;text-transform:uppercase;letter-spacing:.06em}.mock-onboarding-progress{display:flex;gap:6px}.mock-onboarding-dot{width:100%;height:4px;border-radius:999px;background:#ddd5c9}.mock-onboarding-dot.done{background:#2c6e49}.mock-onboarding-dot.active{background:#8fba54}.mock-onboarding-card{display:grid;gap:14px;padding:24px;border:1px solid #d8d0c1;border-radius:14px;background:#fffdf8}.mock-onboarding-card h2{margin:0;font-size:26px;line-height:1.15}.mock-onboarding-copy{margin:0;color:#3f4a44;font-size:15px}.mock-onboarding-fineprint{margin:0;color:#79837d;font-size:13px}.mock-onboarding-actions{display:flex;align-items:center;flex-wrap:wrap;gap:10px;margin-top:4px}.mock-onboarding-divider{color:#79837d;font-size:13px}.mock-form{display:grid;gap:12px}.mock-field{display:grid;gap:6px;font-size:14px;color:#59635d}.mock-input{display:block;border:1px solid #d8d0c1;border-radius:8px;padding:10px 12px;background:#fff;color:#1d2522}.mock-provider-row{display:flex;gap:6px;background:#ece6d7;border-radius:999px;padding:4px;width:fit-content}.mock-provider-tab{padding:6px 14px;border-radius:999px;font-size:13px;color:#59635d}.mock-provider-tab.active{background:#fff;color:#1d2522;font-weight:700;border:1px solid #d8d0c1}.mock-account-summary{display:grid;gap:8px;padding:14px;border:1px solid #d8d0c1;border-radius:12px;background:#f7f4ed}.mock-account-line{display:grid;gap:2px;font-size:14px}.mock-account-label{color:#79837d;font-size:12px;text-transform:uppercase;letter-spacing:.04em}.mock-time-picker{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.mock-time-chip{display:grid;gap:2px;padding:12px;border:1px solid #d8d0c1;border-radius:10px;background:#fff;text-align:center}.mock-time-chip.selected{border-color:#2c6e49;background:#f7fbf8}.mock-time-chip strong{font-size:16px}.mock-time-chip em{color:#2c6e49;font-size:11px;font-style:normal;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.mock-sync-steps.long{font-size:14px}.mock-progress-bar{height:6px;border-radius:999px;background:#ece6d7;overflow:hidden}.mock-progress-fill{display:block;height:100%;background:linear-gradient(90deg,#2c6e49,#8fba54)}.mock-progress-meta{margin:0;color:#79837d;font-size:13px}.mock-finding-stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.mock-finding-stat{display:grid;gap:4px;padding:12px;border:1px solid #d8d0c1;border-radius:10px;background:#f7f4ed}.mock-finding-stat strong{font-size:18px}.mock-finding-stat span{color:#79837d;font-size:13px}.mock-finding-examples{display:grid;gap:8px;padding:14px;border:1px dashed #d8d0c1;border-radius:12px;background:#fff}.mock-finding-examples-label{margin:0;color:#79837d;font-size:12px;text-transform:uppercase;letter-spacing:.05em}.mock-finding-example{display:grid;grid-template-columns:56px minmax(0,1fr);gap:12px;align-items:center}.mock-finding-example strong{display:block;font-size:14px}.mock-finding-example span{color:#79837d;font-size:13px}.mock-board{aspect-ratio:1;border-radius:8px;background:repeating-conic-gradient(#7b9c55 0% 25%,#f1ecd0 0% 50%) 0 0 / 25% 25%;border:1px solid #445042}.mock-board.small{width:56px}.mock-session-chrome{max-width:880px;margin:0 auto;display:grid;gap:14px}.mock-session-topbar{display:flex;align-items:center;justify-content:space-between;padding:4px 2px}.mock-session-wordmark{font-weight:800}.mock-session-exit{border:1px solid #aeb9b1;border-radius:999px;padding:6px 12px;font-size:13px;background:#fff;color:#59635d}.mock-session-body{display:grid;gap:14px}.mock-session-intro{display:grid;gap:14px;padding:24px;border:1px solid #d8d0c1;border-radius:14px;background:#fffdf8}.mock-session-intro h2{margin:0;font-size:24px;line-height:1.2}.mock-session-plan{margin:0;padding:0;list-style:none;display:grid;gap:8px}.mock-session-plan li{display:grid;grid-template-columns:36px minmax(0,1fr) auto;gap:12px;align-items:center;padding:12px;border:1px solid #ebe5db;border-radius:10px;background:#fff}.mock-session-step-index{display:grid;place-items:center;width:30px;height:30px;border-radius:50%;background:#2c6e49;color:#fff;font-weight:700}.mock-session-plan strong{display:block;font-size:14px}.mock-session-plan span,.mock-session-step-meta{color:#79837d;font-size:13px}.mock-session-moment{display:grid;gap:14px;padding:24px;border:1px solid #d8d0c1;border-radius:14px;background:#fffdf8}.mock-session-moment-header h2{margin:0;font-size:22px}.mock-session-board-row{display:grid;grid-template-columns:minmax(0,1fr) 240px;gap:16px;align-items:start}.mock-session-board-row .mock-board{width:100%;max-width:360px;margin-left:auto;margin-right:auto}.mock-session-side{display:grid;gap:12px}.mock-session-meta{display:grid;gap:4px;padding:10px 12px;border:1px solid #ebe5db;border-radius:10px;background:#fff;color:#3f4a44;font-size:13px}.mock-session-prompt{display:grid;gap:8px;padding:14px;border:1px solid #d8d0c1;border-radius:10px;background:#f7fbf8}.mock-session-prompt-label{margin:0;color:#2c6e49;font-size:12px;text-transform:uppercase;letter-spacing:.05em;font-weight:700}.mock-candidate-list{display:grid;gap:6px}.mock-candidate{border:1px solid #d8d0c1;border-radius:8px;padding:8px 10px;background:#fff;color:#1d2522;font-weight:600;text-align:center}.mock-session-footer{display:flex;align-items:center;justify-content:space-between;gap:12px;color:#79837d;font-size:13px}.mock-session-progress{letter-spacing:.4em;color:#2c6e49}.mock-link{color:#2c6e49;font-weight:600;text-decoration:none}.mock-link:hover{text-decoration:underline}.mock-today-fineprint{margin:0;color:#79837d;font-size:13px}.eyebrow.positive{color:#2c6e49}.eyebrow.emphasis{color:#8a6b24}.mock-week-summary{margin:0;padding:0;list-style:none;display:grid;gap:8px}.mock-week-summary li{display:grid;gap:2px;padding:10px 12px;border:1px solid #ebe5db;border-radius:10px;background:#fff}.mock-week-summary li.positive{border-color:#b8d6a4;background:#f7fbf8}.mock-week-summary li.emphasis{border-color:#d8c08b;background:#fbf6ec}.mock-week-summary strong{font-size:14px;color:#1d2522}.mock-week-summary span{color:#79837d;font-size:13px}.mock-pattern-list{margin:0;padding:0;list-style:none;display:grid;gap:8px}.mock-pattern-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;align-items:center;padding:12px 14px;border:1px solid #ebe5db;border-radius:10px;background:#fff}.mock-pattern-row-main{display:grid;gap:4px;min-width:0}.mock-pattern-row-head{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.mock-pattern-row-head strong{font-size:15px}.mock-pattern-trend{display:inline-flex;align-items:center;border-radius:999px;padding:3px 9px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em}.mock-pattern-trend.persistent{color:#8a6b24;background:#d9983b2e}.mock-pattern-trend.emerging{color:#2c6e49;background:#8fba5438}.mock-pattern-trend.improving{color:#2c6e49;background:#2c6e491f}.mock-pattern-trend.stable{color:#59635d;background:#ece6d7}.mock-pattern-blurb{margin:0;color:#59635d;font-size:13px}.mock-pattern-meta{margin:0;display:flex;gap:6px;align-items:center;color:#79837d;font-size:13px}.mock-pattern-meta strong{color:#1d2522}.mock-pattern-compare{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:12px}.mock-pattern-column{align-self:start}.mock-pattern-column.improved{border-color:#b8d6a4;background:#f7fbf8}.mock-pattern-column.costly{border-color:#d8c08b;background:#fbf6ec}.mock-mix-row{display:grid;grid-template-columns:minmax(0,1fr) auto minmax(0,1fr);gap:14px;align-items:center}.mock-mix-card{display:grid;gap:6px;padding:14px;border:1px solid #d8d0c1;border-radius:12px;background:#fff}.mock-mix-card.emphasis{border-color:#b8d6a4;background:#f7fbf8}.mock-mix-card ul{margin:0;padding:0;list-style:none;display:grid;gap:4px;font-size:14px;color:#3f4a44}.mock-mix-card strong{color:#1d2522}.mock-mix-label{color:#79837d;font-size:12px;text-transform:uppercase;letter-spacing:.05em}.mock-mix-arrow{color:#79837d;font-size:22px}.mock-week-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:8px}.mock-week-cell{display:grid;gap:4px;padding:10px;border:1px solid #ebe5db;border-radius:10px;background:#fff;font-size:12px}.mock-week-cell.emphasis{border-color:#b8d6a4;background:#f7fbf8}.mock-week-day{color:#79837d;font-size:11px;text-transform:uppercase;letter-spacing:.06em}.mock-week-cell strong{color:#1d2522;font-size:13px;line-height:1.2}.mock-week-detail{color:#79837d;font-size:11px;line-height:1.3}.mock-watch-list{margin:0;padding:0;list-style:none;display:grid;gap:6px;color:#3f4a44;font-size:14px}.mock-watch-list li{position:relative;padding-left:18px}.mock-watch-list li:before{content:"○";position:absolute;left:0;color:#2c6e49;font-weight:700}.mock-profile-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.mock-profile-stat{display:grid;gap:4px;padding:14px;border:1px solid #ebe5db;border-radius:10px;background:#fff}.mock-profile-stat.positive{border-color:#b8d6a4;background:#f7fbf8}.mock-profile-stat.emphasis{border-color:#d8c08b;background:#fbf6ec}.mock-profile-label{color:#79837d;font-size:12px;text-transform:uppercase;letter-spacing:.05em}.mock-profile-stat strong{font-size:22px;line-height:1.1}.mock-profile-meta{color:#59635d;font-size:12px}.mock-profile-observations{margin:0;padding:0;list-style:none;display:grid;gap:8px}.mock-profile-observations li{display:grid;gap:4px;padding:12px 14px;border:1px solid #ebe5db;border-radius:10px;background:#fff}.mock-profile-observations strong{font-size:14px}.mock-profile-observations span{color:#59635d;font-size:13px}@media(max-width:760px){.mock-pattern-compare,.mock-mix-row{grid-template-columns:minmax(0,1fr)}.mock-week-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.mock-profile-grid{grid-template-columns:minmax(0,1fr)}.mock-mix-arrow{transform:rotate(90deg);justify-self:center}}.design-shell{min-height:100vh;display:grid;grid-template-columns:280px minmax(0,1fr);background:#f4f1ea}.design-sidebar{position:sticky;top:0;align-self:start;height:100vh;overflow-y:auto;padding:22px 18px;border-right:1px solid #d8d0c1;background:#ece6d7;display:grid;gap:18px;align-content:start}.design-sidebar-header{display:grid;gap:6px}.design-sidebar-header h2{margin:0;font-size:20px}.design-direction-card{padding:12px;border:1px solid #d8d0c1;border-radius:10px;background:#fffdf8;display:grid;gap:6px}.design-direction-card h3{margin:0;font-size:14px}.design-direction-card p{margin:0;color:#59635d;font-size:13px;line-height:1.45}.design-direction-refs{color:#79837d!important;font-size:12px!important;font-style:italic}.design-main{display:grid;grid-template-rows:auto minmax(0,1fr);min-width:0}.design-toolbar{display:grid;gap:12px;padding:14px 24px;border-bottom:1px solid #d8d0c1;background:#f4f1ea}.design-direction-tabs{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px}.design-direction-tab{display:grid;gap:2px;padding:10px 14px;border:1px solid #d8d0c1;border-radius:10px;text-decoration:none;background:#fffdf8;color:#1d2522}.design-direction-tab:hover{border-color:#2c6e49}.design-direction-tab-label{font-weight:700;font-size:14px}.design-direction-tab-tagline{color:#79837d;font-size:12px}.design-direction-tab.active.dir-studio{border-color:#2c6e49;background:#f7fbf8}.design-direction-tab.active.dir-character{border-color:#dd6e3c;background:#fdf3eb}.design-direction-tab.active.dir-sport{border-color:#ff5722;background:#fff4f1}.design-direction-tab.active.dir-practice{border-color:#c95e2c;background:#fbe8d8}.design-toolbar-meta{color:#79837d}.design-canvas{padding:24px}.design-canvas.dir-studio{background:#fafaf7}.design-canvas.dir-character{background:#f6efe2}.design-canvas.dir-sport{background:#f5f5f4}.design-canvas.dir-practice{background:#f5f1e9}.studio{--studio-bg: #fafaf7;--studio-surface: #ffffff;--studio-border: #e9e7e1;--studio-text: #0e1112;--studio-muted: #5a6259;--studio-accent: #2c6e49;--studio-accent-soft: #f0f5ee;--studio-honey: #c98e3a;--studio-warning: #fbf6ec;max-width:920px;margin:0 auto;display:grid;gap:28px;font-family:Inter,ui-sans-serif,system-ui,sans-serif;color:var(--studio-text)}.studio-eyebrow{display:inline-block;font-family:Inter,sans-serif;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--studio-muted)}.studio-display,.studio-display.sm,.studio-display.xs{font-family:Bricolage Grotesque,Inter,sans-serif;font-weight:700;letter-spacing:-.025em;line-height:1.02;margin:8px 0;color:var(--studio-text)}.studio-display{font-size:56px;max-width:22ch}.studio-display.sm{font-size:32px;line-height:1.08;max-width:28ch}.studio-display.xs{font-size:20px;line-height:1.15}.studio-lede{margin:0;color:var(--studio-muted);font-size:17px;line-height:1.55;max-width:56ch}.studio-lede.sm{font-size:15px}.studio-nav{display:flex;align-items:center;justify-content:space-between;padding:4px 0}.studio-wordmark{font-family:Bricolage Grotesque,sans-serif;font-weight:700;font-size:17px;letter-spacing:-.02em}.studio-nav-links{display:flex;align-items:center;gap:18px;font-size:14px;color:var(--studio-muted)}.studio-pill{display:inline-flex;align-items:center;justify-content:center;padding:8px 14px;border-radius:8px;font-size:14px;font-weight:600;border:1px solid var(--studio-border);background:var(--studio-surface);color:var(--studio-text);cursor:default;transition:transform .15s ease}.studio-pill.primary{background:var(--studio-accent);color:#fff;border-color:var(--studio-accent)}.studio-pill.ghost{background:transparent}.studio-pill.large{padding:12px 20px;font-size:15px}.studio-cta-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:6px}.studio-hero{padding:40px 36px 36px;border:1px solid var(--studio-border);border-radius:14px;background:var(--studio-surface);display:grid;gap:14px}.studio-bullets{margin:12px 0 0;padding:0;list-style:none;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px 18px;color:var(--studio-text);font-size:14px}.studio-bullets li{position:relative;padding-left:18px}.studio-bullets li:before{content:"→";position:absolute;left:0;color:var(--studio-accent);font-weight:700}.studio-section{display:grid;gap:14px;padding:28px;border:1px solid var(--studio-border);border-radius:14px;background:var(--studio-surface)}.studio-section.sm{padding:20px 22px}.studio-three-up{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.studio-card{padding:18px;border:1px solid var(--studio-border);border-radius:12px;background:var(--studio-bg);display:grid;gap:6px}.studio-card-tag{margin:0;color:var(--studio-honey);font-size:12px;font-weight:700;letter-spacing:.06em}.studio-card h3{margin:4px 0 0;font-family:Bricolage Grotesque,sans-serif;font-size:18px;letter-spacing:-.015em}.studio-card p{margin:0;color:var(--studio-muted);font-size:14px;line-height:1.45}.studio-pricing{text-align:left;display:grid;gap:10px}.studio-pricing .studio-pill{width:fit-content}.studio-progress-label{font-size:12px;font-weight:600;color:var(--studio-muted);letter-spacing:.04em}.studio-progress-bar{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:5px}.studio-progress-dot{height:4px;border-radius:999px;background:var(--studio-border)}.studio-progress-dot.done{background:var(--studio-accent)}.studio-card-hero{padding:32px;border:1px solid var(--studio-border);border-radius:14px;background:var(--studio-surface);display:grid;gap:16px}.studio-finding-stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.studio-stat{display:grid;gap:4px;padding:14px 16px;border:1px solid var(--studio-border);border-radius:10px;background:var(--studio-bg)}.studio-stat strong{font-family:Bricolage Grotesque,sans-serif;font-size:28px;letter-spacing:-.02em;font-weight:700}.studio-stat-text{font-size:18px!important}.studio-stat-unit{font-size:14px;color:var(--studio-muted);font-weight:500;margin-left:2px}.studio-stat-label{color:var(--studio-muted);font-size:12px}.studio-moments{display:grid;gap:8px;padding:14px 16px;border:1px dashed var(--studio-border);border-radius:12px;background:var(--studio-bg)}.studio-moments-label{margin:0;font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--studio-muted)}.studio-moment{display:grid;grid-template-columns:48px minmax(0,1fr);gap:12px;align-items:center}.studio-moment strong{display:block;font-size:14px}.studio-moment span{color:var(--studio-muted);font-size:13px}.studio-moment-board{aspect-ratio:1;width:48px;border-radius:6px;background:repeating-conic-gradient(#7b9c55 0% 25%,#f1ecd0 0% 50%) 0 0 / 25% 25%;border:1px solid #445042}.studio-app-topbar{display:flex;align-items:center;justify-content:space-between;padding:4px 0}.studio-app-identity{display:flex;align-items:baseline;gap:12px}.studio-app-user{font-family:Bricolage Grotesque,sans-serif;font-size:24px;font-weight:700;letter-spacing:-.02em}.studio-app-nav{display:flex;gap:2px;padding:4px;border-radius:999px;border:1px solid var(--studio-border);background:var(--studio-surface)}.studio-app-nav-item{padding:6px 12px;border-radius:999px;font-size:13px;color:var(--studio-muted)}.studio-app-nav-item.active{background:var(--studio-text);color:#fff;font-weight:600}.studio-hero-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:20px;align-items:start}.studio-streak-pulse{display:grid;place-items:center;width:72px;height:72px;border-radius:50%;background:var(--studio-accent);color:#fff;position:relative;animation:studio-pulse 2.4s ease-in-out infinite}.studio-streak-pulse:before{content:"";position:absolute;inset:-6px;border-radius:50%;border:2px solid var(--studio-accent);opacity:.18}.studio-streak-pulse strong{font-family:Bricolage Grotesque,sans-serif;font-size:28px;font-weight:700;line-height:1}.studio-streak-pulse span{font-size:10px;letter-spacing:.05em;text-transform:uppercase;margin-top:2px}@keyframes studio-pulse{0%,to{box-shadow:0 0 #2c6e4938}50%{box-shadow:0 0 0 8px #2c6e4900}}.studio-week-list{margin:0;padding:0;list-style:none;display:grid;gap:8px}.studio-week-list li{display:grid;gap:2px;padding:12px 14px;border:1px solid var(--studio-border);border-radius:10px;background:var(--studio-bg)}.studio-week-list li.positive{border-color:#b8d6a4;background:var(--studio-accent-soft)}.studio-week-list li.emphasis{border-color:#d8c08b;background:var(--studio-warning)}.studio-week-list strong{font-size:14px}.studio-week-list span{color:var(--studio-muted);font-size:13px}.studio-session-card{padding:18px 20px;border:1px solid #b8d6a4;border-radius:12px;background:var(--studio-accent-soft);display:grid;gap:10px}.studio-session-card p{margin:0;color:var(--studio-text);font-size:14px;line-height:1.5}.character{--character-bg: #f6efe2;--character-surface: #fffaf0;--character-border: #e6dac1;--character-text: #2b211a;--character-muted: #7a6a5d;--character-accent: #dd6e3c;--character-accent-soft: #fdf3eb;--character-sage: #8eaa72;--character-sage-soft: #eef3e6;max-width:920px;margin:0 auto;display:grid;gap:24px;font-family:Inter,ui-sans-serif,system-ui,sans-serif;color:var(--character-text)}.character-eyebrow{margin:0;font-family:Inter,sans-serif;font-size:12px;font-weight:600;letter-spacing:.04em;color:var(--character-accent)}.character-display,.character-display.sm,.character-display.xs{font-family:Fraunces,Iowan Old Style,Georgia,serif;font-weight:600;font-style:normal;font-variation-settings:"opsz" 96,"SOFT" 100;letter-spacing:-.01em;line-height:1.05;margin:6px 0;color:var(--character-text)}.character-display{font-size:50px;max-width:22ch}.character-display.sm{font-size:30px;line-height:1.12;max-width:26ch}.character-display.xs{font-size:20px;line-height:1.18}.character-lede{margin:0;color:var(--character-muted);font-size:17px;line-height:1.55;max-width:54ch}.character-lede.sm{font-size:15px}.character-nav{display:flex;align-items:center;justify-content:space-between;padding:4px 0}.character-wordmark{display:inline-flex;align-items:center;gap:8px;font-family:Fraunces,serif;font-weight:600;font-size:18px;letter-spacing:-.01em}.character-mark{display:inline-block;width:14px;height:14px;border-radius:50%;background:radial-gradient(circle at 30% 30%,var(--character-accent),#b8442e 70%)}.character-nav-links{display:flex;align-items:center;gap:14px;font-size:14px;color:var(--character-muted)}.character-pill{display:inline-flex;align-items:center;justify-content:center;padding:9px 16px;border-radius:999px;font-size:14px;font-weight:600;border:1px solid var(--character-border);background:var(--character-surface);color:var(--character-text);cursor:default}.character-pill.primary{background:var(--character-accent);color:#fff;border-color:var(--character-accent);box-shadow:0 1px #b8442e}.character-pill.ghost{background:transparent}.character-pill.large{padding:12px 22px;font-size:15px}.character-cta-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:4px}.character-hero{padding:40px 36px 32px;border:1px solid var(--character-border);border-radius:22px;background:var(--character-surface);display:grid;gap:14px;background-image:radial-gradient(circle at 100% 0%,rgba(221,110,60,.08),transparent 40%)}.character-hero-quip{margin:8px 0 0;font-family:Fraunces,serif;font-style:italic;font-size:14px;color:var(--character-muted)}.character-section{display:grid;gap:14px;padding:24px;border:1px solid var(--character-border);border-radius:22px;background:var(--character-surface)}.character-section.sm{padding:18px 20px}.character-three-up{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.character-card{padding:20px;border:1px solid var(--character-border);border-radius:18px;background:var(--character-bg);display:grid;gap:8px}.character-illustration{font-family:Fraunces,serif;font-size:36px;line-height:1;color:var(--character-accent)}.character-card h3{margin:0;font-family:Fraunces,serif;font-size:18px;letter-spacing:-.005em}.character-card p{margin:0;color:var(--character-muted);font-size:14px;line-height:1.5}.character-pricing{display:grid;gap:10px}.character-progress-label{font-family:Fraunces,serif;font-style:italic;font-size:13px;color:var(--character-muted)}.character-progress-bar{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:6px}.character-progress-dot{height:6px;border-radius:999px;background:var(--character-border)}.character-progress-dot.done{background:var(--character-accent)}.character-card-hero{padding:32px;border:1px solid var(--character-border);border-radius:22px;background:var(--character-surface);display:grid;gap:16px}.character-finding-stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.character-stat{display:grid;gap:4px;padding:16px;border:1px solid var(--character-border);border-radius:16px;background:var(--character-bg)}.character-stat strong{font-family:Fraunces,serif;font-size:30px;font-weight:600;letter-spacing:-.01em;display:flex;align-items:baseline;gap:4px}.character-stat strong span{font-size:14px;color:var(--character-muted);font-weight:500}.character-stat-text{font-size:18px!important}.character-stat-label{color:var(--character-muted);font-size:12px}.character-moments{display:grid;gap:10px;padding:16px 18px;border-radius:18px;background:var(--character-bg);border:1px dashed var(--character-border)}.character-moments-label{margin:0;font-family:Fraunces,serif;font-style:italic;font-size:13px;color:var(--character-muted)}.character-moment{display:grid;grid-template-columns:52px minmax(0,1fr);gap:14px;align-items:center}.character-moment strong{display:block;font-family:Fraunces,serif;font-weight:600;font-size:15px}.character-moment span{color:var(--character-muted);font-size:13px}.character-moment-board{aspect-ratio:1;width:52px;border-radius:10px;background:repeating-conic-gradient(#c98e3a 0% 25%,#f6efe2 0% 50%) 0 0 / 25% 25%;border:1px solid var(--character-border)}.character-fineprint{margin:0;font-family:Fraunces,serif;font-style:italic;color:var(--character-muted);font-size:13px}.character-app-topbar{display:flex;align-items:center;justify-content:space-between;padding:4px 0}.character-app-identity{display:flex;align-items:baseline;gap:12px}.character-app-user{font-family:Fraunces,serif;font-style:italic;font-size:16px;color:var(--character-muted)}.character-app-nav{display:flex;gap:4px;padding:4px;border-radius:999px;background:var(--character-bg);border:1px solid var(--character-border)}.character-app-nav-item{padding:7px 14px;border-radius:999px;font-size:13px;color:var(--character-muted)}.character-app-nav-item.active{background:var(--character-surface);color:var(--character-text);font-weight:700;box-shadow:0 1px #0000000a}.character-hero-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:20px;align-items:center}.character-streak{display:grid;place-items:center;padding:16px 18px;border:1px solid var(--character-border);border-radius:22px;background:var(--character-accent-soft);text-align:center}.character-streak-flame{font-size:22px;color:var(--character-accent);line-height:1}.character-streak strong{font-family:Fraunces,serif;font-size:30px;font-weight:600;margin:4px 0 2px;line-height:1}.character-streak span{font-size:11px;color:var(--character-muted);text-transform:uppercase;letter-spacing:.04em}.character-week-list{margin:0;padding:0;list-style:none;display:grid;gap:8px}.character-week-list li{display:grid;gap:4px;padding:14px 16px;border:1px solid var(--character-border);border-radius:14px;background:var(--character-bg)}.character-week-list li.positive{border-color:#c8d8b3;background:var(--character-sage-soft)}.character-week-list li.emphasis{border-color:#e6c789;background:#fbf1dd}.character-week-list strong{font-family:Fraunces,serif;font-weight:600;font-size:15px}.character-week-list span{color:var(--character-muted);font-size:13px}.character-session-card{padding:20px;border:1px solid #c8d8b3;border-radius:18px;background:var(--character-sage-soft);display:grid;gap:10px}.character-session-card p{margin:0;font-size:14px;line-height:1.55;color:var(--character-text)}.sport{--sport-bg: #f5f5f4;--sport-surface: #ffffff;--sport-border: #e7e5e4;--sport-text: #0a0a0a;--sport-muted: #525252;--sport-accent: #ff5722;--sport-accent-soft: #fff4f1;--sport-positive: #65a30d;--sport-positive-soft: #f4faea;--sport-warning: #c2410c;--sport-warning-soft: #fef3ea;max-width:1000px;margin:0 auto;display:grid;gap:24px;font-family:Inter,ui-sans-serif,system-ui,sans-serif;color:var(--sport-text)}.sport-eyebrow{margin:0;font-family:Inter,sans-serif;font-size:11px;font-weight:700;letter-spacing:.16em;color:var(--sport-muted)}.sport-display,.sport-display.sm,.sport-display.xs{font-family:Inter,sans-serif;font-weight:800;letter-spacing:-.04em;line-height:.95;margin:8px 0;color:var(--sport-text);text-transform:uppercase}.sport-display{font-size:64px;max-width:16ch}.sport-display.sm{font-size:34px;line-height:1;letter-spacing:-.03em;max-width:22ch}.sport-display.xs{font-size:18px;line-height:1.05}.sport-display-accent{color:var(--sport-accent)}.sport-lede{margin:0;color:var(--sport-muted);font-size:16px;line-height:1.5;max-width:56ch}.sport-lede.sm{font-size:14px}.sport-nav{display:flex;align-items:center;justify-content:space-between;padding:4px 0}.sport-wordmark{font-family:Inter,sans-serif;font-weight:900;font-size:14px;letter-spacing:.06em}.sport-nav-links{display:flex;align-items:center;gap:16px;font-family:Inter,sans-serif;font-weight:700;font-size:12px;letter-spacing:.08em;color:var(--sport-muted)}.sport-pill{display:inline-flex;align-items:center;justify-content:center;padding:9px 16px;border-radius:4px;font-family:Inter,sans-serif;font-weight:700;font-size:12px;letter-spacing:.08em;border:1px solid var(--sport-border);background:var(--sport-surface);color:var(--sport-text);cursor:default}.sport-pill.primary{background:var(--sport-accent);color:#fff;border-color:var(--sport-accent)}.sport-pill.ghost{background:transparent}.sport-pill.large{padding:14px 22px;font-size:13px}.sport-cta-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:4px}.sport-hero{padding:36px 32px 28px;border:1px solid var(--sport-border);border-radius:6px;background:var(--sport-surface);display:grid;gap:16px}.sport-stat-row{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:0;margin-top:12px;border-top:1px solid var(--sport-border);border-left:1px solid var(--sport-border)}.sport-stat-row.inline{margin-top:4px}.sport-stat-block{padding:16px 18px;border-right:1px solid var(--sport-border);border-bottom:1px solid var(--sport-border);display:grid;gap:6px}.sport-stat-block.accent{background:var(--sport-accent-soft)}.sport-stat-label{font-family:Inter,sans-serif;font-weight:700;font-size:10px;letter-spacing:.14em;color:var(--sport-muted)}.sport-stat-block strong{font-family:JetBrains Mono,ui-monospace,SFMono-Regular,monospace;font-size:32px;font-weight:700;letter-spacing:-.02em;line-height:1;color:var(--sport-text);display:flex;align-items:baseline;gap:3px}.sport-stat-block strong span{font-size:14px;color:var(--sport-muted);font-weight:500}.sport-stat-text{font-family:Inter,sans-serif!important;font-size:18px!important;font-weight:800!important;text-transform:uppercase;line-height:1!important}.sport-stat-meta{font-family:Inter,sans-serif;font-size:10px;font-weight:700;letter-spacing:.1em;color:var(--sport-muted)}.sport-section{display:grid;gap:14px;padding:28px;border:1px solid var(--sport-border);border-radius:6px;background:var(--sport-surface)}.sport-section.sm{padding:20px 22px}.sport-method-list{margin:0;padding:0;list-style:none;display:grid;gap:6px}.sport-method-list li{display:grid;grid-template-columns:48px auto minmax(0,1fr);gap:14px;align-items:baseline;padding:14px 0;border-bottom:1px solid var(--sport-border)}.sport-method-list li:last-child{border-bottom:0}.sport-method-num{font-family:JetBrains Mono,monospace;font-size:18px;font-weight:700;color:var(--sport-accent)}.sport-method-list strong{font-family:Inter,sans-serif;font-weight:800;font-size:18px;text-transform:uppercase;letter-spacing:-.01em}.sport-method-list span{color:var(--sport-muted);font-size:14px}.sport-pricing{display:grid;gap:10px}.sport-progress-label{font-family:JetBrains Mono,monospace;font-size:12px;font-weight:700;color:var(--sport-muted);letter-spacing:.1em}.sport-progress-bar{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:4px}.sport-progress-dot{height:3px;background:var(--sport-border)}.sport-progress-dot.done{background:var(--sport-accent)}.sport-card-hero{padding:32px;border:1px solid var(--sport-border);border-radius:6px;background:var(--sport-surface);display:grid;gap:18px}.sport-moments{display:grid;gap:4px;padding:16px 18px;border:1px solid var(--sport-border);border-radius:4px;background:var(--sport-bg)}.sport-moments-label{margin:0 0 6px;font-family:Inter,sans-serif;font-weight:700;font-size:10px;letter-spacing:.14em;color:var(--sport-muted)}.sport-moment{display:grid;grid-template-columns:48px minmax(0,1fr) auto;gap:14px;align-items:center;padding:10px 0;border-bottom:1px solid var(--sport-border)}.sport-moment:last-of-type{border-bottom:0}.sport-moment strong{font-family:Inter,sans-serif;font-weight:800;font-size:14px;letter-spacing:.02em;display:block}.sport-moment span{font-family:JetBrains Mono,monospace;color:var(--sport-muted);font-size:11px;letter-spacing:.05em}.sport-moment-board{aspect-ratio:1;width:48px;border-radius:2px;background:repeating-conic-gradient(#262626 0% 25%,#e5e5e4 0% 50%) 0 0 / 25% 25%;border:1px solid #262626}.sport-moment-cost{font-family:JetBrains Mono,monospace!important;color:var(--sport-warning)!important;font-size:14px!important;font-weight:700;letter-spacing:0!important}.sport-app-topbar{display:flex;align-items:center;justify-content:space-between;padding:4px 0 14px;border-bottom:1px solid var(--sport-border)}.sport-app-identity{display:flex;align-items:baseline;gap:14px}.sport-app-user{font-family:JetBrains Mono,monospace;font-size:13px;letter-spacing:.06em;color:var(--sport-muted)}.sport-app-nav{display:flex;gap:0;border:1px solid var(--sport-border);border-radius:4px;background:var(--sport-surface);overflow:hidden}.sport-app-nav-item{padding:8px 14px;font-family:Inter,sans-serif;font-weight:700;font-size:11px;letter-spacing:.1em;color:var(--sport-muted);border-right:1px solid var(--sport-border)}.sport-app-nav-item:last-child{border-right:0}.sport-app-nav-item.active{background:var(--sport-text);color:#fff}.sport-hero-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:24px;align-items:center}.sport-streak-block{display:grid;place-items:center;padding:18px 22px;border:1px solid var(--sport-border);border-radius:4px;background:var(--sport-bg);text-align:center}.sport-streak-block strong{font-family:JetBrains Mono,monospace;font-size:44px;font-weight:700;line-height:1;letter-spacing:-.04em;color:var(--sport-accent)}.sport-streak-block span{font-family:Inter,sans-serif;font-weight:700;font-size:10px;letter-spacing:.14em;color:var(--sport-muted);margin-top:4px}.sport-streak-meta{color:var(--sport-positive)!important;margin-top:2px!important;letter-spacing:.04em!important}.sport-metric-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:0;border-top:1px solid var(--sport-border);border-left:1px solid var(--sport-border)}.sport-metric{padding:16px 18px;border-right:1px solid var(--sport-border);border-bottom:1px solid var(--sport-border);display:grid;gap:6px;background:var(--sport-surface)}.sport-metric.positive{background:var(--sport-positive-soft)}.sport-metric.warning{background:var(--sport-warning-soft)}.sport-metric.emphasis{background:var(--sport-accent-soft)}.sport-metric-label{font-family:Inter,sans-serif;font-weight:700;font-size:10px;letter-spacing:.14em;color:var(--sport-muted)}.sport-metric strong{font-family:JetBrains Mono,monospace;font-size:28px;font-weight:700;letter-spacing:-.03em;line-height:1;display:flex;align-items:baseline;gap:3px}.sport-metric strong span{font-size:13px;color:var(--sport-muted);font-weight:500}.sport-metric.positive strong{color:var(--sport-positive)}.sport-metric.warning strong{color:var(--sport-warning)}.sport-metric-meta{font-family:Inter,sans-serif;font-weight:700;font-size:10px;letter-spacing:.1em;color:var(--sport-muted)}.sport-session-card{padding:20px 22px;border:1px solid var(--sport-text);border-radius:4px;background:var(--sport-surface);display:grid;gap:12px;position:relative}.sport-session-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--sport-accent)}.sport-session-card p{margin:0;font-size:14px;line-height:1.5;color:var(--sport-muted)}.practice{--practice-bg: #f5f1e9;--practice-surface: #fffaf0;--practice-border: #e6dcc7;--practice-text: #1f1814;--practice-muted: #7a6a5d;--practice-accent: #c95e2c;--practice-accent-soft: #fbe8d8;--practice-sage: #7d9d68;--practice-sage-soft: #eef3e6;--practice-warning: #c08947;--practice-warning-soft: #faf0dd;max-width:920px;margin:0 auto;display:grid;gap:26px;font-family:Inter,ui-sans-serif,system-ui,sans-serif;color:var(--practice-text)}.practice-eyebrow{display:inline-block;font-family:Inter,sans-serif;font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--practice-muted)}.practice-display,.practice-display.sm,.practice-display.xs{font-family:Fraunces,Iowan Old Style,Georgia,serif;font-weight:600;font-variation-settings:"opsz" 96,"SOFT" 30;letter-spacing:-.015em;line-height:1.04;margin:6px 0;color:var(--practice-text)}.practice-display{font-size:44px;max-width:22ch}.practice-display.sm{font-size:28px;line-height:1.1;max-width:28ch}.practice-display.xs{font-size:18px;line-height:1.18}.practice-lede{margin:0;color:var(--practice-muted);font-size:16px;line-height:1.55;max-width:56ch}.practice-lede.sm{font-size:14.5px}.practice-nav{display:flex;align-items:center;justify-content:space-between;padding:4px 0}.practice-wordmark{display:inline-flex;align-items:center;gap:8px;font-family:Fraunces,serif;font-weight:600;font-size:17px;letter-spacing:-.01em}.practice-mark{display:inline-block;width:12px;height:12px;border-radius:3px;background:var(--practice-accent);transform:rotate(45deg)}.practice-nav-links{display:flex;align-items:center;gap:16px;font-size:14px;color:var(--practice-muted)}.practice-pill{display:inline-flex;align-items:center;justify-content:center;padding:8px 14px;border-radius:8px;font-size:14px;font-weight:600;border:1px solid var(--practice-border);background:var(--practice-surface);color:var(--practice-text);cursor:default}.practice-pill.primary{background:var(--practice-accent);color:#fff;border-color:var(--practice-accent)}.practice-pill.ghost{background:transparent}.practice-pill.large{padding:12px 20px;font-size:15px}.practice-cta-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:4px}.practice-hero{padding:36px 32px 30px;border:1px solid var(--practice-border);border-radius:14px;background:var(--practice-surface);display:grid;gap:14px}.practice-bullets{margin:12px 0 0;padding:0;list-style:none;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px 18px;color:var(--practice-text);font-size:14px}.practice-bullets li{position:relative;padding-left:20px}.practice-bullets li:before{content:"◆";position:absolute;left:0;font-size:9px;top:6px;color:var(--practice-accent)}.practice-section{display:grid;gap:14px;padding:26px;border:1px solid var(--practice-border);border-radius:14px;background:var(--practice-surface)}.practice-section.sm{padding:20px 22px}.practice-three-up{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.practice-card{padding:18px;border:1px solid var(--practice-border);border-radius:12px;background:var(--practice-bg);display:grid;gap:6px}.practice-card-tag{margin:0;font-family:Inter,sans-serif;color:var(--practice-accent);font-size:12px;font-weight:700;letter-spacing:.06em}.practice-card h3{margin:4px 0 0;font-family:Fraunces,serif;font-weight:600;font-size:19px;letter-spacing:-.005em}.practice-card p{margin:0;color:var(--practice-muted);font-size:14px;line-height:1.5}.practice-pricing{display:grid;gap:10px}.practice-progress-label{font-size:12px;font-weight:600;color:var(--practice-muted);letter-spacing:.04em}.practice-progress-bar{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:5px}.practice-progress-dot{height:5px;border-radius:999px;background:var(--practice-border)}.practice-progress-dot.done{background:var(--practice-accent)}.practice-card-hero{padding:30px;border:1px solid var(--practice-border);border-radius:14px;background:var(--practice-surface);display:grid;gap:14px}.practice-finding-stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.practice-stat{display:grid;gap:4px;padding:14px 16px;border:1px solid var(--practice-border);border-radius:10px;background:var(--practice-bg)}.practice-stat strong{font-family:Fraunces,serif;font-weight:600;font-size:26px;letter-spacing:-.01em;line-height:1}.practice-stat-text{font-family:Fraunces,serif!important;font-size:17px!important;line-height:1.1!important}.practice-stat-unit{font-family:Inter,sans-serif;font-size:13px;color:var(--practice-muted);font-weight:500;margin-left:2px}.practice-stat-label{color:var(--practice-muted);font-size:12px;line-height:1.35}.practice-moments{display:grid;gap:8px;padding:14px 16px;border:1px dashed var(--practice-border);border-radius:12px;background:var(--practice-bg)}.practice-moments-label{margin:0;font-family:Inter,sans-serif;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--practice-muted)}.practice-moment{display:grid;grid-template-columns:48px minmax(0,1fr);gap:12px;align-items:center}.practice-moment strong{display:block;font-family:Fraunces,serif;font-weight:600;font-size:15px}.practice-moment span{color:var(--practice-muted);font-size:13px}.practice-moment-board{aspect-ratio:1;width:48px;border-radius:6px;background:repeating-conic-gradient(#c08947 0% 25%,#fbe8d8 0% 50%) 0 0 / 25% 25%;border:1px solid var(--practice-border)}.practice-fineprint{margin:0;color:var(--practice-muted);font-size:13px}.practice-app-topbar{display:flex;align-items:center;justify-content:space-between;padding:4px 0}.practice-app-identity{display:flex;align-items:baseline;gap:12px}.practice-app-user{font-family:Fraunces,serif;font-size:24px;font-weight:600;letter-spacing:-.01em}.practice-app-nav{display:flex;gap:2px;padding:4px;border-radius:999px;border:1px solid var(--practice-border);background:var(--practice-surface)}.practice-app-nav-item{padding:6px 12px;border-radius:999px;font-size:13px;color:var(--practice-muted)}.practice-app-nav-item.active{background:var(--practice-accent);color:#fff;font-weight:600}.practice-hero-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:20px;align-items:center}.practice-streak{display:grid;place-items:center;width:76px;height:76px;border-radius:50%;background:var(--practice-accent-soft);border:1px solid var(--practice-accent);text-align:center}.practice-streak strong{font-family:Fraunces,serif;font-size:28px;font-weight:600;line-height:1;color:var(--practice-accent)}.practice-streak span{font-size:10px;letter-spacing:.05em;text-transform:uppercase;margin-top:4px;color:var(--practice-muted)}.practice-week-list{margin:0;padding:0;list-style:none;display:grid;gap:8px}.practice-week-list li{display:grid;gap:2px;padding:12px 14px;border:1px solid var(--practice-border);border-radius:10px;background:var(--practice-bg)}.practice-week-list li.positive{border-color:#b8c9a4;background:var(--practice-sage-soft)}.practice-week-list li.emphasis{border-color:#d8c08b;background:var(--practice-warning-soft)}.practice-week-list strong{font-family:Fraunces,serif;font-weight:600;font-size:15px}.practice-week-list span{color:var(--practice-muted);font-size:13px}.practice-session-card{padding:18px 20px;border:1px solid var(--practice-accent);border-radius:12px;background:var(--practice-accent-soft);display:grid;gap:10px}.practice-session-card p{margin:0;color:var(--practice-text);font-size:14px;line-height:1.55}.content-demo{max-width:1280px}.content-demo-link{color:inherit;text-decoration:none}.content-demo-entry-list{display:grid;gap:10px}.content-demo-entry{display:grid;gap:6px;padding:16px 18px;border:1px solid var(--practice-border);border-radius:18px;background:var(--practice-bg);color:var(--practice-text);text-decoration:none}.content-demo-entry.active{border-color:var(--practice-accent);background:var(--practice-accent-soft)}.content-demo-entry-topline{display:flex;align-items:center;justify-content:space-between;gap:12px}.content-demo-entry strong{font-family:Fraunces,serif;font-size:18px;line-height:1.1}.content-demo-entry span{color:var(--practice-muted);font-size:14px;line-height:1.5}.content-demo-status,.content-demo-stage{display:inline-flex;align-items:center;justify-content:center;padding:5px 10px;border-radius:999px;border:1px solid var(--practice-border);font-size:11px!important;font-weight:700;letter-spacing:.08em;text-transform:uppercase;white-space:nowrap}.content-demo-status.ready,.content-demo-stage.final{border-color:#c8d8b3;background:var(--practice-sage-soft);color:#4d6741}.content-demo-status.needs-review,.content-demo-stage.derived{border-color:#e6c789;background:var(--practice-warning-soft);color:#8a6330}.content-demo-stage.source{border-color:var(--practice-border);background:var(--practice-bg);color:var(--practice-muted)}.content-demo-artifact-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.content-demo-artifact-card{display:grid;gap:12px;padding:18px;border:1px solid var(--practice-border);border-radius:18px;background:var(--practice-bg)}.content-demo-artifact-card img{width:100%;border-radius:12px;border:1px solid var(--practice-border);background:#fff}.content-demo-artifact-copy{display:grid;gap:4px}.content-demo-artifact-copy strong{font-family:Fraunces,serif;font-size:18px;line-height:1.1}.content-demo-artifact-copy p{margin:0;color:var(--practice-muted);font-size:14px;line-height:1.55}.content-demo-json-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.content-demo-json-card{display:grid;gap:12px;min-width:0;padding:18px;border:1px solid var(--practice-border);border-radius:18px;background:var(--practice-bg)}.content-demo-json-card-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.content-demo-json-card-header strong{font-family:Fraunces,serif;font-size:18px;line-height:1.1}.content-demo-json-card pre{margin:0;padding:14px;overflow:auto;border-radius:14px;border:1px solid var(--practice-border);background:#fffdf8;color:var(--practice-text);font-size:12px;line-height:1.55}.foundations-gallery-search-row{margin-bottom:14px}.foundations-gallery-search{width:100%}.foundations-gallery-section-stack{display:grid;gap:18px}.foundations-gallery-section{display:grid;gap:12px}.foundations-gallery-section-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.foundations-gallery-section-header strong{display:block;font-family:Fraunces,serif;font-size:22px;line-height:1.1}.foundations-gallery-section-header span{color:var(--practice-muted);font-size:13px}.foundations-gallery-entry-list{max-height:320px;overflow:auto;padding-right:4px}.foundations-gallery-metrics{gap:10px}.foundations-gallery-chip-row{display:flex;flex-wrap:wrap;gap:8px}.foundations-gallery-visual-grid{align-items:start}.foundations-board-shell{padding:8px;border-radius:12px;border:1px solid var(--practice-border);background:#fff}.foundations-gallery-secondary-grid{margin-top:14px}.foundations-gallery-empty{display:grid;min-height:320px;place-items:center;border-radius:12px;border:1px dashed var(--practice-border);color:var(--practice-muted);background:#fffdf8;text-align:center;padding:24px}.foundations-gallery-metadata-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.foundations-gallery-metadata-card{align-content:start}.foundations-gallery-metadata-list{display:grid;gap:10px;margin:0}.foundations-gallery-metadata-row{display:grid;gap:4px;padding-bottom:10px;border-bottom:1px solid var(--practice-border)}.foundations-gallery-metadata-row:last-child{border-bottom:0;padding-bottom:0}.foundations-gallery-metadata-row dt{font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--practice-muted)}.foundations-gallery-metadata-row dd{margin:0;word-break:break-word;color:var(--practice-text);font-size:14px;line-height:1.5}.foundations-gallery-notes{display:grid;gap:8px}.foundations-gallery-notes strong{font-family:Fraunces,serif;font-size:16px;line-height:1.1}.foundations-gallery-notes ul{margin:0;padding-left:18px;color:var(--practice-muted);font-size:13px;line-height:1.5}@media(max-width:900px){.design-shell{grid-template-columns:minmax(0,1fr)}.design-sidebar{position:static;height:auto;border-right:0;border-bottom:1px solid #d8d0c1}.design-direction-tabs{grid-template-columns:repeat(2,minmax(0,1fr))}.studio-three-up,.character-three-up,.practice-three-up,.sport-stat-row,.sport-metric-grid,.studio-finding-stats,.character-finding-stats,.practice-finding-stats,.studio-bullets,.practice-bullets,.studio-hero-row,.character-hero-row,.practice-hero-row,.sport-hero-row,.content-demo-artifact-grid,.content-demo-json-grid,.foundations-gallery-metadata-grid{grid-template-columns:minmax(0,1fr)}.content-demo-json-card-header,.content-demo-entry-topline{align-items:start;flex-direction:column}}.mock-pill{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:8px 14px;font-size:14px;font-weight:600;border:1px solid transparent;background:#fff;color:#1d2522;cursor:default}.mock-pill.primary{background:#2c6e49;color:#fff;border-color:#2c6e49}.mock-pill.ghost{background:transparent;border-color:#aeb9b1}.mock-pill.large{padding:12px 20px;font-size:15px}.mock-marketing{max-width:960px;margin:0 auto;display:grid;gap:36px}.mock-marketing-nav{display:flex;align-items:center;justify-content:space-between;padding:6px 2px}.mock-marketing-wordmark{font-weight:800;font-size:18px;letter-spacing:-.01em}.mock-marketing-nav-links{display:flex;align-items:center;gap:18px;color:#59635d;font-size:14px}.mock-marketing-hero{display:grid;gap:16px;padding:36px 32px 32px;border:1px solid #d8d0c1;border-radius:18px;background:#fffdf8}.mock-marketing-hero h1{margin:0;font-size:44px;line-height:1.05;max-width:24ch}.mock-marketing-subhead{margin:0;color:#59635d;font-size:17px;max-width:56ch}.mock-marketing-cta-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:8px}.mock-marketing-bullets{margin:14px 0 0;padding:0;list-style:none;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px 18px;color:#3f4a44;font-size:14px}.mock-marketing-bullets li:before{content:"·";margin-right:8px;color:#2c6e49;font-weight:800}.mock-marketing-section{display:grid;gap:14px;padding:24px;border:1px solid #d8d0c1;border-radius:14px;background:#fffdf8}.mock-marketing-section h2{margin:0;font-size:26px}.mock-marketing-section h3{margin:0 0 6px;font-size:17px}.mock-loop-steps,.mock-numbered-list{margin:0;padding-left:20px;display:grid;gap:6px;color:#3f4a44;font-size:15px}.mock-three-up{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.mock-card{border:1px solid #d8d0c1;border-radius:12px;background:#f7f4ed;padding:16px}.mock-card p{margin:0;color:#59635d}.mock-callout-stack{display:grid;gap:8px}.mock-callout{border-left:3px solid #2c6e49;background:#f7fbf8;padding:12px 14px;border-radius:6px;color:#2c342f}.mock-marketing-pricing{text-align:left}.mock-today{max-width:880px;margin:0 auto;display:grid;gap:18px}.mock-today-topbar{display:flex;align-items:end;justify-content:space-between;gap:16px;padding:0 4px}.mock-today-topbar h1{font-size:28px}.mock-today-nav{display:flex;gap:4px;background:#ece6d7;border:1px solid #d8d0c1;border-radius:999px;padding:4px}.mock-today-nav-item{padding:6px 12px;border-radius:999px;font-size:13px;color:#59635d}.mock-today-nav-item.active{background:#fff;color:#1d2522;font-weight:700;border:1px solid #d8d0c1}.mock-today-body{display:grid;gap:14px}.mock-today-hero{padding:24px;border:1px solid #d8d0c1;border-radius:14px;background:#fffdf8;display:grid;gap:12px}.mock-today-hero h2{margin:0;font-size:26px;line-height:1.15;max-width:32ch}.mock-today-hero.celebrate{background:linear-gradient(180deg,#f4fbf1,#fffdf8);border-color:#b8d6a4}.mock-today-hero.syncing{background:linear-gradient(180deg,#f3f0e6,#fffdf8)}.mock-today-hero.shifting{background:linear-gradient(180deg,#fbf6ec,#fffdf8);border-color:#e0cfa3}.mock-today-hero.quiet{background:#f7f4ed}.mock-today-copy{margin:0;color:#3f4a44;font-size:15px}.mock-today-copy.quiet{color:#79837d}.mock-today-section{padding:18px 20px;border:1px solid #d8d0c1;border-radius:12px;background:#fffdf8;display:grid;gap:10px}.mock-today-section.muted{background:#f7f4ed}.mock-streak-row{display:grid;grid-template-columns:auto minmax(0,1fr);gap:16px;align-items:center;padding:12px;border:1px dashed #b8d6a4;border-radius:12px;background:#f7fbf8}.mock-streak-badge{display:grid;justify-items:center;width:64px;height:64px;border-radius:50%;background:#2c6e49;color:#fff}.mock-streak-badge strong{font-size:24px;line-height:1;margin-top:12px}.mock-streak-badge span{font-size:10px;text-transform:uppercase;letter-spacing:.05em;margin-top:2px}.mock-streak-meta{display:grid;gap:4px;font-size:14px;color:#3f4a44}.mock-streak-meta p{margin:0}.mock-checklist{margin:0;padding:0;list-style:none;display:grid;gap:6px;color:#3f4a44;font-size:14px}.mock-check{display:inline-grid;place-items:center;width:18px;height:18px;margin-right:8px;border-radius:50%;background:#2c6e49;color:#fff;font-size:11px;vertical-align:middle}.mock-tomorrow-preview{border:1px dashed #d8d0c1;border-radius:10px;padding:12px 14px;color:#3f4a44;font-size:14px}.mock-tomorrow-preview p{margin:0}.mock-sync-steps{margin:4px 0 0;padding:0;list-style:none;display:grid;gap:6px;color:#79837d;font-size:14px}.mock-sync-steps li:before{content:"○";margin-right:8px;color:#c4cec7;font-weight:800}.mock-sync-steps li.done{color:#3f4a44}.mock-sync-steps li.done:before{content:"●";color:#2c6e49}.mock-sync-steps li.active{color:#1d2522;font-weight:600}.mock-sync-steps li.active:before{content:"◐";color:#2c6e49}.mock-change-list{margin:0;padding:0;list-style:none;display:grid;gap:8px}.mock-change-list li{display:grid;gap:2px;padding:10px 12px;border:1px solid #ebe5db;border-radius:10px;background:#fff}.mock-change-list li.emphasis{border-color:#d8c08b;background:#fbf6ec}.mock-change-list strong{font-size:14px;color:#1d2522}.mock-change-list span{color:#79837d;font-size:13px}.mock-session-card{display:grid;gap:8px;padding:18px;border:1px solid #b8d6a4;border-radius:12px;background:#f7fbf8}.mock-session-card h3{margin:0;font-size:18px}.mock-session-card p{margin:0;color:#3f4a44;font-size:14px}.mock-session-card .mock-pill{justify-self:start;margin-top:4px}@media(max-width:900px){.preview-shell{grid-template-columns:minmax(0,1fr)}.preview-sidebar{position:static;height:auto;border-right:0;border-bottom:1px solid #d8d0c1}.mock-marketing-bullets,.mock-three-up{grid-template-columns:minmax(0,1fr)}.mock-today-topbar{flex-direction:column;align-items:start}}@media(max-width:760px){.app-shell{padding:18px}.training-budget-panel,.topbar,.account-block{align-items:start}.training-budget-panel,.topbar{flex-direction:column}.review-shell,.review-player-banner,.review-side-score-grid{grid-template-columns:minmax(0,1fr)}.review-header,.review-meta-chip-row{align-items:start;justify-content:start;flex-direction:column}.review-versus{display:none}.paginator,.paginator-controls{align-items:start;flex-direction:column}.page-number-row{flex-wrap:wrap}.game-row{grid-template-columns:minmax(0,1fr);gap:8px}.game-list-header{display:none}.game-side,.game-link,.game-actions{justify-self:start}.game-actions{flex-wrap:wrap}.scoreline{justify-items:start;grid-template-columns:repeat(2,max-content)}.moves-cell,.date-cell{text-align:left}}.foundations-gallery{max-width:1440px;margin:0 auto;padding:18px 28px 48px;display:grid;gap:18px;font-family:Inter,ui-sans-serif,system-ui,sans-serif;color:var(--practice-text)}.fg-topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:8px 4px;border-bottom:1px solid var(--practice-border)}.fg-brand{display:flex;align-items:center;gap:10px;font-size:14px}.fg-brand .practice-mark{width:12px;height:12px}.fg-brand-name{font-weight:700;letter-spacing:.01em}.fg-brand-divider{color:var(--practice-muted)}.fg-brand-route{font-family:Fraunces,serif;font-size:16px;font-weight:600;letter-spacing:-.005em}.fg-topbar-nav{display:flex;align-items:center;gap:14px;font-size:13px}.fg-topbar-nav a{color:var(--practice-muted);text-decoration:none}.fg-topbar-nav a:hover{color:var(--practice-accent)}.fg-shell{display:grid;grid-template-columns:320px minmax(0,1fr);gap:20px;align-items:start}.fg-sidebar{position:sticky;top:16px;display:flex;flex-direction:column;gap:12px;height:calc(100vh - 32px);padding:14px;border:1px solid var(--practice-border);border-radius:12px;background:var(--practice-surface);overflow:hidden}.fg-sidebar-summary,.fg-sidebar-filters{flex:0 0 auto}.fg-status-filter{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:6px}.fg-status-filter:has(.fg-status-button:nth-child(4)){grid-template-columns:repeat(4,minmax(0,1fr))}.fg-status-button{display:grid;gap:1px;padding:8px 6px 7px;border-radius:8px;border:1px solid var(--practice-border);background:var(--practice-bg);color:var(--practice-muted);cursor:pointer;text-align:center;font-family:inherit;transition:background .12s,border-color .12s,color .12s}.fg-status-button:hover{border-color:var(--practice-muted);color:var(--practice-text)}.fg-status-button strong{font-family:Fraunces,serif;font-size:18px;font-weight:600;line-height:1;color:inherit}.fg-status-button span{font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.fg-status-button.active{background:var(--practice-accent-soft);border-color:var(--practice-accent);color:var(--practice-accent)}.fg-status-button.tone-happy.active{background:var(--practice-sage-soft);border-color:#98ad7d;color:#4d6741}.fg-status-button.tone-unhappy.active{background:var(--practice-warning-soft);border-color:#d8b169;color:#8a6330}.fg-sidebar-filters{display:grid;gap:8px}.fg-search{width:100%;padding:8px 10px;font-size:13px;border:1px solid var(--practice-border);border-radius:8px;background:var(--practice-bg);color:var(--practice-text)}.fg-search:focus{outline:2px solid var(--practice-accent);outline-offset:0}.fg-book-filter{display:flex;gap:4px;padding:3px;background:var(--practice-bg);border:1px solid var(--practice-border);border-radius:999px}.fg-book-chip{flex:1;padding:5px 10px;font-size:12px;font-weight:600;letter-spacing:.01em;border-radius:999px;border:0;background:transparent;color:var(--practice-muted);cursor:pointer}.fg-book-chip.active{background:var(--practice-accent);color:#fff}.fg-sidebar-list{flex:1 1 auto;min-height:0;overflow:auto;display:flex;flex-direction:column;gap:14px;margin:-4px;padding:4px}.fg-sidebar-empty{margin:0;padding:16px;font-size:13px;color:var(--practice-muted);text-align:center}.fg-list-section-header{display:flex;align-items:baseline;justify-content:space-between;padding:4px 4px 6px;border-bottom:1px solid var(--practice-border);margin-bottom:6px}.fg-list-section-header strong{font-family:Fraunces,serif;font-size:14px;font-weight:600}.fg-list-section-header span{font-size:11px;font-weight:600;letter-spacing:.05em;color:var(--practice-muted)}.fg-list{display:grid;gap:2px;margin:0;padding:0;list-style:none}.fg-list-row{display:grid;gap:1px;padding:7px 8px;border-radius:6px;text-decoration:none;color:var(--practice-text);border:1px solid transparent}.fg-list-row:hover{background:var(--practice-bg)}.fg-list-row.active{background:var(--practice-accent-soft);border-color:var(--practice-accent)}.fg-list-row-id{font-family:JetBrains Mono,ui-monospace,monospace;font-size:12px;font-weight:600;color:var(--practice-text)}.fg-list-row-meta{font-size:11px;color:var(--practice-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fg-list-row-meta em{font-style:italic;color:var(--practice-muted);opacity:.7}.fg-detail{min-width:0}.fg-detail-loading{padding:60px 20px;text-align:center;font-size:14px;color:var(--practice-muted);border:1px dashed var(--practice-border);border-radius:12px;background:var(--practice-surface)}.fg-detail-article{display:grid;gap:18px}.fg-detail-header{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:16px;align-items:start;padding:18px 22px;border:1px solid var(--practice-border);border-radius:12px;background:var(--practice-surface)}.fg-detail-heading{display:grid;gap:4px;min-width:0}.fg-detail-eyebrow{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--practice-muted)}.fg-detail-title{margin:0;font-family:Fraunces,serif;font-weight:600;font-size:26px;line-height:1.15;letter-spacing:-.01em}.fg-detail-title-empty{font-style:italic;color:var(--practice-muted);font-weight:500}.fg-detail-id{font-family:JetBrains Mono,ui-monospace,monospace;font-size:12px;color:var(--practice-muted)}.fg-detail-pills{display:flex;flex-wrap:wrap;gap:6px;justify-content:flex-end}.fg-pill{display:inline-flex;align-items:center;padding:3px 9px;font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;border-radius:999px;border:1px solid var(--practice-border);background:var(--practice-bg);color:var(--practice-muted);white-space:nowrap}.fg-pill-happy{border-color:#b8c9a4;background:var(--practice-sage-soft);color:#4d6741}.fg-pill-unhappy{border-color:#e6c789;background:var(--practice-warning-soft);color:#8a6330}.fg-pill-neutral{border-color:var(--practice-border);background:var(--practice-bg);color:var(--practice-muted)}.fg-artifacts{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.fg-artifact{display:grid;gap:10px;padding:14px;border:1px solid var(--practice-border);border-radius:12px;background:var(--practice-surface)}.fg-artifact-header{display:flex;align-items:baseline;justify-content:space-between;gap:8px}.fg-artifact-header strong{font-family:Fraunces,serif;font-size:16px;font-weight:600}.fg-artifact-header code{font-family:JetBrains Mono,ui-monospace,monospace;font-size:11px;color:var(--practice-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:60%}.fg-artifact-media{display:block;border-radius:8px;overflow:hidden;background:#fff;border:1px solid var(--practice-border)}.fg-artifact-media img{display:block;width:100%;height:auto}.fg-artifact-board{padding:12px;display:grid;place-items:center}.fg-artifact-board img{max-width:100%;height:auto}.fg-artifact-board .foundations-board-shell{width:100%;max-width:480px;border:0;padding:0;background:transparent}.fg-artifact-empty{display:grid;place-items:center;min-height:240px;border:1px dashed var(--practice-border);border-radius:8px;color:var(--practice-muted);font-size:13px}.fg-artifact-warning{margin:0;padding:8px 10px;font-size:12px;line-height:1.45;color:#8a6330;background:var(--practice-warning-soft);border:1px solid #e6c789;border-radius:8px}.fg-artifact-warning strong{font-weight:700}.fg-artifact-caption{margin:0;font-size:12px;color:var(--practice-muted);display:flex;gap:6px;align-items:center}.fg-artifact-caption code{font-family:JetBrains Mono,ui-monospace,monospace;font-size:11px;color:#4d6741;background:var(--practice-sage-soft);padding:1px 6px;border-radius:4px}.fg-solution{display:grid;gap:10px;padding:16px 18px;border:1px solid #b8c9a4;border-radius:12px;background:var(--practice-sage-soft)}.fg-solution-empty{border-color:var(--practice-border);background:var(--practice-surface)}.fg-solution-header{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.fg-solution-header strong{font-family:Fraunces,serif;font-size:16px;font-weight:600;color:#4d6741}.fg-solution-empty .fg-solution-header strong{color:var(--practice-muted)}.fg-solution-moves{margin:0;padding:0;list-style:none;display:flex;flex-wrap:wrap;gap:8px 16px}.fg-solution-moves li{display:inline-flex;align-items:baseline;gap:6px}.fg-solution-move-number{font-size:11px;font-weight:700;letter-spacing:.04em;color:var(--practice-muted);min-width:22px;text-align:right}.fg-solution-move-san{font-family:Fraunces,serif;font-size:16px;font-weight:600;color:var(--practice-text)}.fg-solution-move-uci{font-family:JetBrains Mono,ui-monospace,monospace;font-size:11px;color:#4d6741;background:#7d9d682e;padding:1px 5px;border-radius:4px}.fg-solution-raw{margin:0;display:flex;align-items:baseline;gap:8px;font-size:12px;color:var(--practice-muted)}.fg-solution-raw span{font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.fg-solution-raw code{font-family:JetBrains Mono,ui-monospace,monospace;font-size:12px;color:var(--practice-text)}.fg-solution-empty-note{margin:0;font-size:13px;color:var(--practice-muted)}.fg-secondary{display:grid;grid-template-columns:2fr 1fr;gap:16px}.fg-secondary-card{display:grid;gap:10px;padding:14px;border:1px solid var(--practice-border);border-radius:12px;background:var(--practice-surface)}.fg-secondary-media{display:block;border-radius:8px;overflow:hidden;background:#fff;border:1px solid var(--practice-border)}.fg-secondary-media>img{display:block;width:100%;max-height:420px;object-fit:contain;object-position:top}.fg-artifact-media>img{max-height:480px;width:100%;object-fit:contain;object-position:center}.fg-meta{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.fg-meta-card{display:grid;gap:10px;padding:16px;border:1px solid var(--practice-border);border-radius:12px;background:var(--practice-surface)}.fg-meta-card-header strong{font-family:Fraunces,serif;font-size:15px;font-weight:600}.fg-meta-list{display:grid;gap:8px;margin:0}.fg-meta-row{display:grid;grid-template-columns:140px minmax(0,1fr);gap:10px;align-items:baseline;padding:4px 0;border-bottom:1px dashed var(--practice-border);font-size:13px}.fg-meta-row:last-child{border-bottom:0}.fg-meta-row dt{font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--practice-muted)}.fg-meta-row dd{margin:0;word-break:break-word;color:var(--practice-text)}.fg-meta-row.muted dd{color:var(--practice-muted);font-style:italic}.fg-meta-mono{font-family:JetBrains Mono,ui-monospace,monospace;font-size:12px}.fg-meta-notes{display:grid;gap:6px;padding-top:8px;border-top:1px solid var(--practice-border)}.fg-meta-notes strong{font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--practice-muted)}.fg-meta-notes ul{margin:0;padding-left:16px;color:var(--practice-text);font-size:12px;line-height:1.45}@media(max-width:1100px){.fg-shell{grid-template-columns:minmax(0,1fr)}.fg-sidebar{position:static;max-height:none}.fg-sidebar-list{max-height:360px}.fg-artifacts,.fg-secondary,.fg-meta,.fg-detail-header{grid-template-columns:minmax(0,1fr)}.fg-detail-pills{justify-content:flex-start}}.puzzle-board-shell{position:relative;width:100%;max-width:100%;aspect-ratio:1 / 1;border-radius:14px;overflow:hidden;border:1px solid var(--practice-border, #e6dcc7)}.puzzle-board.cg-wrap{position:absolute;inset:0;width:100%;height:100%;box-sizing:border-box}.puzzle-board.cg-wrap cg-container,.puzzle-board.cg-wrap cg-board{inset:0;width:100%!important;height:100%!important}.cg-wrap cg-board{background-color:#f1ecd0;background-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20width='2'%20height='2'%3E%3Crect%20width='2'%20height='2'%20fill='%23f1ecd0'/%3E%3Crect%20x='1'%20width='1'%20height='1'%20fill='%237b9c55'/%3E%3Crect%20y='1'%20width='1'%20height='1'%20fill='%237b9c55'/%3E%3C/svg%3E");background-size:25%}.cg-wrap cg-board square.last-move{background-color:#7d9d686b}.cg-wrap cg-board square.selected{background-color:#7d9d688c}.cg-wrap cg-board square.move-dest{background:radial-gradient(rgba(20,85,30,.3) 22%,transparent 24%)}.cg-wrap cg-board square.oc.move-dest{background:radial-gradient(transparent 0%,transparent 78%,rgba(20,85,30,.3) 80%)}.promotion-picker{position:absolute;inset:0;z-index:5;background:#141c108c}.promotion-picker__cell{position:absolute;width:12.5%;height:12.5%;margin:0;padding:0;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;background:#f1ecd0;box-shadow:inset 0 0 0 2px #14551e99;transition:background-color .12s ease,transform .12s ease}.promotion-picker__cell:hover,.promotion-picker__cell:focus-visible{background:#fff7d6;outline:none;transform:scale(1.04)}.promotion-picker__glyph{line-height:1;font-size:clamp(1.4rem,7vw,3rem)}.promotion-picker__cell.white .promotion-picker__glyph{color:#fff;-webkit-text-stroke:1.5px #23311b}.promotion-picker__cell.black .promotion-picker__glyph{color:#23311b}.operator-solve{max-width:540px;margin:0 auto;padding:24px 16px 48px;font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;color:#23311b}.operator-solve__head h1{font-size:1.1rem;margin:0 0 4px}.operator-solve__meta{margin:0 0 16px;color:#5b6650;font-size:.9rem}.operator-solve__board{width:100%;max-width:480px;margin:0 auto}.operator-solve__status{display:flex;align-items:center;gap:12px;margin:16px 0 8px;min-height:2rem}.operator-solve__solved{font-weight:700;color:#2f7d32}.operator-solve__feedback,.operator-solve__error{color:#b3261e}.operator-solve__solution{color:#5b6650;font-size:.85rem}.badge-gallery{min-height:100dvh;padding:24px 28px 64px;background:#f4efe2;font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;color:#23311b}.badge-gallery__head h1{font-size:1.15rem;margin:0 0 4px}.badge-gallery__head p{margin:0 0 20px;color:#6f6a58;font-size:.9rem}.badge-gallery__error{color:#b3261e}.badge-gallery__grid{display:grid;grid-template-columns:repeat(6,1fr);gap:16px}.badge-card{margin:0;background:#fff;border-radius:16px;padding:20px 12px 16px;display:flex;flex-direction:column;align-items:center;text-align:center;box-shadow:0 1px 4px #0000001a}.badge-card__art{width:104px;height:104px}.badge-card__meta{display:flex;flex-direction:column;gap:3px;margin-top:10px}.badge-card__name{font-size:.92rem;font-weight:600}.badge-card__desc{font-size:.78rem;color:#6f6a58}.solve-screen{min-height:100dvh;display:flex;flex-direction:column;background:var(--practice-bg);color:var(--practice-text);font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif}.solve-strip{flex:0 0 auto;display:flex;justify-content:space-between;align-items:center;gap:12px;padding:6px 14px;background:var(--practice-surface);border-bottom:1px solid var(--practice-border);font-size:13px}.solve-stats{display:flex;gap:8px;align-items:baseline;color:var(--practice-muted)}.solve-stats strong{color:var(--practice-text);font-weight:700}.solve-account{position:relative;display:flex;gap:10px;align-items:center}.solve-account-name{color:var(--practice-muted)}.solve-signout{border:1px solid var(--practice-border);border-radius:8px;background:transparent;color:var(--practice-muted);font:inherit;font-size:12px;padding:3px 8px;cursor:pointer}.solve-menu-button{display:inline-flex;flex-direction:column;justify-content:center;gap:3px;width:34px;height:34px;border:1px solid var(--practice-border);border-radius:10px;background:transparent;padding:0 8px;cursor:pointer}.solve-menu-button span{display:block;width:100%;height:2px;background:var(--practice-text);border-radius:999px}.solve-menu{position:absolute;top:calc(100% + 8px);right:0;min-width:180px;display:flex;flex-direction:column;gap:6px;padding:10px;background:var(--practice-surface);border:1px solid var(--practice-border);border-radius:14px;box-shadow:0 18px 40px #0f172a29;z-index:10}.solve-menu button{border:1px solid var(--practice-border);border-radius:9px;background:transparent;color:var(--practice-text);font:inherit;font-size:13px;padding:8px 10px;text-align:left;cursor:pointer}.solve-instruction{flex:0 0 auto;display:flex;justify-content:space-between;align-items:center;gap:12px;padding:10px 16px}.solve-instruction-text{font-size:16px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.solve-rating{flex:0 0 auto;font-size:13px;font-weight:700;color:var(--practice-sage);background:var(--practice-sage-soft);border-radius:999px;padding:2px 10px}.solve-board-area{flex:1 1 auto;display:flex;align-items:center;justify-content:center;min-height:0;padding:0 12px}.solve-board-area .puzzle-board-shell{width:min(100%,calc(100dvh - 200px));max-width:480px}.solve-action-area{flex:0 0 auto;min-height:64px;display:flex;align-items:center;justify-content:center;gap:16px;padding:12px 16px}.solve-result.correct{font-size:18px;font-weight:700;color:var(--practice-sage)}.solve-result.wrong{display:flex;align-items:center;gap:16px;font-size:14px;color:var(--practice-warning)}.solve-result.wrong code{font-size:13px}.solve-next{border:1px solid var(--practice-accent);background:var(--practice-accent);color:#fff;font:inherit;font-weight:600;border-radius:10px;padding:8px 18px;cursor:pointer}.solve-empty{flex:1 1 auto;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;color:var(--practice-muted);text-align:center;padding:24px}.solve-empty-hint code{background:var(--practice-surface);border:1px solid var(--practice-border);border-radius:6px;padding:4px 8px;font-size:13px}.solve-avatar{width:28px;height:28px;border-radius:50%;object-fit:cover;border:1px solid var(--practice-border)}.login-actions{display:flex;flex-direction:column;align-items:stretch;gap:10px;max-width:320px;width:100%;align-self:center}.google-signin{border:1px solid var(--practice-border);border-radius:12px;background:var(--practice-surface);color:var(--practice-text);font:inherit;font-weight:600;font-size:15px;padding:11px 22px;cursor:pointer}.google-signin:hover{border-color:var(--practice-accent)}.google-signin:disabled,.local-dev-signin:disabled{opacity:.6;cursor:not-allowed}.local-dev-signin{border:1px dashed var(--practice-border);border-radius:12px;background:transparent;color:var(--practice-muted);font:inherit;font-size:13px;padding:8px 16px;cursor:pointer}.local-dev-signin:hover{color:var(--practice-text)}.onboarding{min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:24px;background:#f4efe2;font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;color:#1d2522}.onboarding-card{width:100%;max-width:460px;background:#fffdf8;border:1px solid #d8d0c1;border-radius:16px;padding:32px 28px;box-shadow:0 2px 12px #00000014}.onboarding-card h1{margin:0 0 8px;font-size:24px}.onboarding-lead{margin:0 0 22px;color:#3f4a44;font-size:15px}.onboarding-actions{display:flex;flex-wrap:wrap;gap:10px}.onboarding-options{display:grid;gap:10px}.onboarding-primary,.onboarding-secondary,.onboarding-option{font:inherit;border-radius:10px;padding:12px 16px;cursor:pointer;border:1px solid #d8d0c1}.onboarding-primary{background:#2c6e49;color:#fff;border-color:#2c6e49;font-weight:700}.onboarding-secondary{background:#fff;color:#59635d}.onboarding-option{background:#fff;text-align:left}.onboarding-option:hover{background:#f7fbf8;border-color:#b8d6a4}.onboarding-option:disabled{opacity:.5;cursor:default}.onboarding-error{margin:14px 0 0;color:#b3261e;font-size:13px}.session-card-screen{min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:24px;background:#f4efe2;font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;color:#1d2522}.session-card{width:100%;max-width:460px;background:#fffdf8;border:1px solid #d8d0c1;border-radius:16px;padding:32px 28px;box-shadow:0 2px 12px #00000014}.session-card-eyebrow{margin:0 0 4px;color:#79837d;font-size:13px;text-transform:uppercase;letter-spacing:.05em;font-weight:700}.session-card-streak{margin:0 0 12px;color:#8a6b24;font-weight:700}.session-card-theme{margin:0 0 10px;font-size:26px}.session-card-lead{margin:0 0 8px;font-size:15px;color:#3f4a44}.session-card-curator{margin:0 0 24px;font-size:13px;color:#79837d;font-style:italic}.session-card-start{font:inherit;font-weight:700;background:#2c6e49;color:#fff;border:none;border-radius:10px;padding:12px 28px;cursor:pointer}.solve-dots{display:flex;gap:6px;flex-wrap:wrap;align-items:center}.solve-dot{width:9px;height:9px;border-radius:50%;background:#d8d0c1}.solve-dot.filled{background:#2c6e49}.solve-done{display:grid;gap:8px;place-items:center;padding:56px 24px;text-align:center}.solve-done h1{margin:0;font-size:22px}.solve-done p{margin:0;color:#59635d}.solve-progress-bar{width:120px;height:6px;border-radius:999px;background:#d8d0c1;overflow:hidden}.solve-progress-fill{display:block;height:100%;background:#2c6e49;transition:width .25s ease}.solve-clue{font:inherit;font-size:.85rem;background:#fff;color:#5b6650;border:1px solid #d8d0c1;border-radius:999px;padding:6px 14px;cursor:pointer}.solve-clue:disabled{opacity:.45;cursor:default}.goal-modal-screen{min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:24px;background:#f4efe2;font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;color:#1d2522}.goal-modal{width:100%;max-width:460px;background:#fffdf8;border:1px solid #d8d0c1;border-radius:16px;padding:32px 28px;box-shadow:0 2px 12px #00000014}.goal-modal-eyebrow{margin:0 0 4px;color:#79837d;font-size:13px;text-transform:uppercase;letter-spacing:.05em;font-weight:700}.goal-modal h1{margin:0 0 22px;font-size:24px}.goal-modal-actions{display:grid;gap:10px}.goal-modal-choice{font:inherit;display:grid;gap:2px;text-align:left;padding:12px 16px;border:1px solid #d8d0c1;border-radius:10px;background:#fff;cursor:pointer}.goal-modal-choice:hover{background:#f7fbf8;border-color:#b8d6a4}.goal-modal-choice-main{font-weight:600}.goal-modal-choice-note{font-size:12px;color:#79837d}.goal-modal-wrap{font:inherit;margin-top:4px;padding:10px 16px;border:1px solid #d8d0c1;border-radius:10px;background:#fff;color:#59635d;cursor:pointer}.solve-bonus-strip{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.solve-bonus-chip{font-size:12px;font-weight:700;color:#2c6e49;background:#2c6e491f;border-radius:999px;padding:3px 10px}.solve-bonus-count{font-size:12px;color:#79837d}.solve-wrapup{font:inherit;font-size:12px;background:#fff;color:#59635d;border:1px solid #d8d0c1;border-radius:999px;padding:4px 12px;cursor:pointer}.badge-toasts{position:fixed;top:16px;left:50%;transform:translate(-50%);display:grid;gap:8px;z-index:50}.badge-toast{display:flex;align-items:center;gap:10px;background:#fffdf8;border:1px solid #d8d0c1;border-radius:12px;padding:8px 14px 8px 8px;box-shadow:0 4px 14px #00000026}.badge-toast-text{display:grid;gap:1px}.badge-toast-label{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:#2c6e49;font-weight:700}.badge-toast-name{font-size:14px;font-weight:600;color:#1d2522}.closer-screen{min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:24px;background:#f4efe2;font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;color:#1d2522}.closer{width:100%;max-width:460px;background:#fffdf8;border:1px solid #d8d0c1;border-radius:16px;padding:32px 28px;box-shadow:0 2px 12px #00000014;text-align:center}.closer-eyebrow{margin:0 0 4px;color:#8a6b24;font-weight:700;font-size:13px}.closer h1{margin:0 0 8px;font-size:24px}.closer-stats{margin:0 0 20px;color:#3f4a44;font-size:15px}.closer-badges{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;margin-bottom:20px}.closer-badge{margin:0;display:grid;gap:4px;justify-items:center;width:80px;font-size:12px;color:#59635d}.closer-comeback{margin:0 0 18px;color:#3f4a44;font-size:14px}.closer-link{color:#2c6e49;font-weight:600;text-decoration:none}.solve-strip-left{display:flex;align-items:center;gap:14px;flex-wrap:wrap}.solve-chips{display:flex;gap:8px}.solve-chip{font-size:12px;font-weight:700;color:#59635d;background:#fff;border:1px solid #d8d0c1;border-radius:999px;padding:3px 9px}.solve-chip-link{text-decoration:none}.badges-page{min-height:100dvh;padding:24px 28px 64px;background:#f4efe2;font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;color:#1d2522}.badges-page-head{margin-bottom:20px}.badges-page-back{color:#2c6e49;font-weight:600;text-decoration:none;font-size:14px}.badges-page-head h1{margin:8px 0 2px;font-size:22px}.badges-page-head p{margin:0;color:#79837d;font-size:14px}.badges-page-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:16px}.badges-page-card{margin:0;background:#fffdf8;border:1px solid #d8d0c1;border-radius:14px;padding:18px 12px;display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center}.badges-page-card.locked{opacity:.5;filter:grayscale(.85)}.badges-page-meta{display:grid;gap:3px}.badges-page-name{font-weight:600;font-size:14px}.badges-page-desc{font-size:12px;color:#79837d}.closer-actions{display:flex;flex-direction:column;align-items:center;gap:12px}.closer-keep-going{font:inherit;font-weight:700;background:#2c6e49;color:#fff;border:none;border-radius:10px;padding:12px 28px;cursor:pointer}.session-card-adaptive{margin:0 0 8px;color:#8a6b24;font-weight:600;font-size:14px}.solve-menu-sim{display:flex;flex-direction:column;gap:4px;padding-top:6px;margin-top:2px;border-top:1px solid #e5ddcb}.solve-menu-sim-days{display:flex;align-items:center;gap:6px;font-size:12px;color:#59635d}.solve-menu-sim-days input{width:46px}
